使用C#语言读取config配置文件

2024-09-01 17:18

本文主要是介绍使用C#语言读取config配置文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天根据看着别人的代码,写了一下读取config配置文件的方法。

配置文件主要是xml类型的文件,主要是写在网站中,主要通过三部来读取配置文件。

(1)加载配置文件

(2)遍历xml文档,将键值对添加到dictionary中

(3)通过字典,来获取键对应的值

主要代码如下

using System;
using System.Collections.Generic;
using System.Xml;namespace Library
{/// <summary>/// 通过GetConfig.getAppValue(string key)来得到config文件中的值/// </summary>public static class GetConfig{//存放键值对static Dictionary<string, string> dic = new Dictionary<string, string>();/// <summary>/// 加载配置文件/// </summary>public static void getMyConfig(){XmlDocument xml = new XmlDocument();//获取应用的当前路径string appPath = AppDomain.CurrentDomain.BaseDirectory;//加载xml文件xml.Load(appPath + "\\WebSystem.config");XmlElement xnode = (XmlElement)xml.SelectSingleNode("configuration");//读取config子节点,并将值写入到字典中SetValues(dic, xnode);}/// <summary>/// 通过键,来获取相应的值/// </summary>/// <param name="key">键</param>/// <returns>值</returns>        public static string getAppValue(string key){getMyConfig();if (!string.IsNullOrEmpty(key) && dic.ContainsKey(key.ToLower()))return dic[key.ToLower()];elsereturn null;}//重载,如果没有获取到值,返回默认值public static string getAppValue(string key,string defaultValue){getMyConfig();if (!string.IsNullOrEmpty(key) && dic.ContainsKey(key.ToLower()))return dic[key.ToLower()];elsereturn defaultValue;}/// <summary>/// 检查键值对中是否有值/// </summary>/// <param name="node">节点</param>/// <returns></returns>private static bool checkNode(XmlNode node){if (node.Attributes["key"] != null && node.Attributes["value"] != null)return true;elsereturn false;}#region/// <summary>/// 将config文件中的值,读取到dictionary中/// </summary>/// <param name="dic">存放键值对的dictionary</param>/// <param name="xnode">xml文档的节点</param>private static void SetValues(Dictionary<string,string> dic, XmlElement xnode){foreach(XmlNode xmlnode in xnode.ChildNodes){if (xmlnode.Name == "appSettings"){ //遍历节点,文档结构如下,将节点键值对存入到dictionary中//<clear/>// <add key="SiteNameEN" value="IFAWebApp"/>//<remove/>foreach (XmlNode node in xmlnode){switch (node.Name){case "clear":dic.Clear();break;case "add":if (checkNode(node))dic.Add(node.Attributes["key"].Value.ToLower(), node.Attributes["value"].Value.ToLower());break;case "remove":if(checkNode(node))dic.Remove(node.Attributes["key"].Value.ToLower());break;}}}}}#endregion}
}


这篇关于使用C#语言读取config配置文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127563

相关文章

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左