一、问题需求: 在项目中经常遇到需要写配置文件地方,目的就是不想在程序中关于一些信息写死,发布的时候只需要修改一下配置文件就可以,不需要每次都修改程序,如项目名称、数据库连接字符串、IP端口之类 的;对于小项目或者服务程序,配置信息可以通过系统自带的appSettings进行配置,但大项目或者配置信息太多,如果都用appSettings来配置就感觉比较杂乱,运维人员在修改配置的时候不好修改,而且如果想找某一模块相关或者某一节点配置容易出错,这时如果能分类管理,例如跟数据库相关的写到一个节点里,跟某个业务独立相关的可以也能单独写一个节点上 等等;

二、解决方案:其实 使用.net自带的configSections,将配置信息分块管理,并提供实体类且还能单配置文件管理,这样程序员可以根据业务类型等其他方式分类写入配置文件,运维人员可以针对某一项进行修改部署维护;

三、具体实现:接下来演示一下几种自定义的configSections节点,有单节点配置、多节点配置、自定义节点配置

        1、  首先演示一下单节点配置:

1.1 新建一个类继承ConfigurationSection,新增属性及调用方法

  1. /// <summary>
  2. /// 单级自定义配置节点
  3. /// </summary>
  4. public class CustomerSingleConfig:ConfigurationSection
  5. {
  6. /// <summary>
  7. /// 获取配置信息
  8. /// </summary>
  9. /// <returns></returns>
  10. public static CustomerSingleConfig GetConfig()
  11. {
  12. return GetConfig("CustomerSingleConfig");
  13. }
  14. /// <summary>
  15. /// 获取配置信息
  16. /// </summary>
  17. /// <param name="sectionName"></param>
  18. /// <returns></returns>
  19. public static CustomerSingleConfig GetConfig(string sectionName)
  20. {
  21. CustomerSingleConfig section = (CustomerSingleConfig)ConfigurationManager.GetSection(sectionName);
  22. if (section == null)
  23. throw new ConfigurationErrorsException("Section " + sectionName + " is not found.");
  24. return section;
  25. }
  26.  
  27. /// <summary>
  28. /// 平台中文名称
  29. /// </summary>
  30. [ConfigurationProperty("PlatChName",DefaultValue = "", IsRequired = true, IsKey = false)]
  31. public string PlatChName
  32. {
  33. get { return (string)this["PlatChName"]; }
  34. set { this["PlatChName"]=value; }
  35. }
  36.  
  37. /// <summary>
  38. /// 平台英文名称
  39. /// </summary>
  40. [ConfigurationProperty("PlatEnName",DefaultValue = "", IsRequired = true, IsKey = false)]
  41. public string PlatEnName
  42. {
  43. get { return (string)this["PlatEnName"]; }
  44. set { this["PlatEnName"] = value; }
  45. }
  46.  
  47. }

1.2 在app.config------>configuration--------->configSections里面加入CustomerSingleConfig节点,如下:

  1. <!--单级配置节点测试-->
  2. <section name="CustomerSingleConfig" type="ConfigDemo.CustomerSingleConfig,ConfigDemo"/>

1.3 在app.config------>configuration------->新建CustomerSingleConfig里面加入配置信息

  1. <CustomerSingleConfig PlatChName="监控平台系统" PlatEnName="Monitoring platform system"></CustomerSingleConfig>

1.4 调用获取配置信息

  1. static void Main(string[] args)
  2. {
  3. Console.WriteLine("---------------------单级配置节点测试-----------------");
  4. Console.WriteLine("PlatChName:" + CustomerSingleConfig.GetConfig().PlatChName);
  5. Console.WriteLine("PlatEnName:" + CustomerSingleConfig.GetConfig().PlatEnName);
  6. }

1.5 运行效果如下

1.6 针对1.3还可以更进一步分离配置写法,可以单独配置成一个config文件

将1.3 <section name="CustomerSingleConfig" type="ConfigDemo.CustomerSingleConfig,ConfigDemo"/>这个节点内容换成如下配置:

<CustomerSingleConfig configSource="CfgFiles\CustomerSingleConfig.config" />

再新一个CfgFiles文件夹在文件里面新增CustomerSingleConfig.config:

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <CustomerMultiConfig >
  3. <CustomerElement connectionString="Data Source='.';Initial Catalog='UniDataNH';User ID='sa';Password='123456'" enabled="true"></CustomerElement>
  4. </CustomerMultiConfig>

整体截图配置如下:


     2、接下来演示一下多级节点

2.1先定义一个子节点类CustomerElement继承ConfigurationElement

  1. public class CustomerElement:ConfigurationElement
  2. {
  3. private const string EnablePropertyName = "enabled";
  4.  
  5. private const string ConnectionStringPropery = "connectionString";
  6.  
  7. [ConfigurationProperty(EnablePropertyName, IsRequired = true)]
  8. public bool Enabled
  9. {
  10. get { return (bool)base[EnablePropertyName]; }
  11. set { base[EnablePropertyName] = value; }
  12. }
  13.  
  14. [ConfigurationProperty(ConnectionStringPropery, IsRequired = true)]
  15. public string ConnectionString
  16. {
  17. get { return (string)base[ConnectionStringPropery]; }
  18. set { base[ConnectionStringPropery] = value; }
  19. }
  20. }

2.2再定一个配置节点类CustomerMultiConfig继承ConfigurationSection,和单个节点配置一样

  1. namespace ConfigDemo
  2. {
  3. /// <summary>
  4. /// 多级配置文件自定义节点配置
  5. /// </summary>
  6. public class CustomerMultiConfig:ConfigurationSection
  7. {
  8. private const string CustomerConfigPropertyName = "CustomerElement";
  9. /// <summary>
  10. /// 获取配置信息
  11. /// </summary>
  12. /// <returns></returns>
  13. public static CustomerMultiConfig GetConfig()
  14. {
  15. return GetConfig("CustomerMultiConfig");
  16. }
  17. /// <summary>
  18. /// 获取配置信息
  19. /// </summary>
  20. /// <param name="sectionName">xml节点名称</param>
  21. /// <returns></returns>
  22. public static CustomerMultiConfig GetConfig(string sectionName)
  23. {
  24. CustomerMultiConfig section = (CustomerMultiConfig)ConfigurationManager.GetSection(sectionName);
  25. if (section == null)
  26. throw new ConfigurationErrorsException("Section " + sectionName + " is not found.");
  27. return section;
  28. }
  29. [ConfigurationProperty(CustomerConfigPropertyName)]
  30. public CustomerElement CustomerElementConfig
  31. {
  32. get { return (CustomerElement)base[CustomerConfigPropertyName]; }
  33. set { base[CustomerConfigPropertyName] = value; }
  34. }
  35. }
  36. }

2.3  接下就是在app.config------>configuration--------->configSections里面加入CustomerMultiConfig节点,详细步骤和单节点一下 如图配置

2.4 调用获取配置信息代码如下:

  1. Console.WriteLine("---------------------多级配置节点测试-----------------");
  2. Console.WriteLine("connectionString:" + CustomerMultiConfig.GetConfig().CustomerElementConfig.Enabled);
  3. Console.WriteLine("enabled:" + CustomerMultiConfig.GetConfig().CustomerElementConfig.ConnectionString);

2.5  运行效果如下图:


3、再演示一下自定义节点配置,可以随意添加配置节点信息

3.1 具体操作步骤类似,代码如下:

  1. namespace ConfigDemo
  2. {
  3. public class TestConfigInfo : ConfigurationSection
  4. {
  5. [ConfigurationProperty("trackers", IsDefaultCollection = false)]
  6. public trackers Trackers { get { return (trackers)base["trackers"]; } }
  7. /// <summary>
  8. /// 获取配置信息
  9. /// </summary>
  10. /// <returns></returns>
  11. public static TestConfigInfo GetConfig()
  12. {
  13. return GetConfig("TestConfigInfo");
  14. }
  15. /// <summary>
  16. /// 获取配置信息
  17. /// </summary>
  18. /// <param name="sectionName">xml节点名称</param>
  19. /// <returns></returns>
  20. public static TestConfigInfo GetConfig(string sectionName)
  21. {
  22. TestConfigInfo section = (TestConfigInfo)ConfigurationManager.GetSection(sectionName);
  23. if (section == null)
  24. throw new ConfigurationErrorsException("Section " + sectionName + " is not found.");
  25. return section;
  26. }
  27. [ConfigurationProperty("TestName", IsRequired = false)]
  28. public string TestName
  29. {
  30. get { return (string)base["TestName"]; }
  31. set { base["TestName"] = value; }
  32. }
  33. [ConfigurationProperty("TestID", IsRequired = false)]
  34. public string TestID
  35. {
  36. get { return (string)base["TestID"]; }
  37. set { base["TestID"] = value; }
  38. }
  39. }
  40.  
  41. public class trackers : ConfigurationElementCollection
  42. {
  43. [ConfigurationProperty("TrackerName", IsRequired = false)]
  44. public string TrackerName
  45. {
  46. get { return (string)base["TrackerName"]; }
  47. set { base["TrackerName"] = value; }
  48. }
  49. protected override ConfigurationElement CreateNewElement()
  50. {
  51. return new tracker();
  52. }
  53.  
  54. protected override object GetElementKey(ConfigurationElement element)
  55. {
  56. return ((tracker)element).Host;
  57. }
  58. }
  59. public class tracker : ConfigurationElement
  60. {
  61. #region 配置節設置,設定檔中有不能識別的元素、屬性時,使其不報錯
  62.  
  63. protected override bool OnDeserializeUnrecognizedAttribute(string name, string value)
  64. {
  65. return base.OnDeserializeUnrecognizedAttribute(name, value);
  66.  
  67. }
  68.  
  69. protected override bool OnDeserializeUnrecognizedElement(string elementName, System.Xml.XmlReader reader)
  70. {
  71. return base.OnDeserializeUnrecognizedElement(elementName, reader);
  72.  
  73. }
  74. #endregion
  75.  
  76. [ConfigurationProperty("Host", DefaultValue = "localhost", IsRequired = true)]
  77. public string Host { get { return this["Host"].ToString(); } }
  78.  
  79. [ConfigurationProperty("Port", DefaultValue = "", IsRequired = true)]
  80. public int Port { get { return (int)this["Port"]; } }
  81.  
  82. }
  83. }

3.2  在CfgFiles新建TestConfigInfo.Config配置文件

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <TestConfigInfo TestName="lxsh" TestID="">
  3. <trackers TrackerName="testName">
  4. <add Host="60.195.251.71" Port="" />
  5. <add Host="60.195.251.72" Port="" />
  6. <add Host="60.195.251.73" Port="" />
  7. </trackers>
  8. </TestConfigInfo>

3.3  右键TestConfigInfo.Config属性,选择输出目录为始终复制,这样操作目地是在运行目录下面生成该文件(其他配置文件也需要这样操作)

3.4  调用获取配置信息代码如下:

  1. Console.WriteLine("---------------------自定义新增节点测试-----------------");
  2. Console.WriteLine("TestID:" + TestConfigInfo.GetConfig().TestID);
  3. Console.WriteLine("TestName:" + TestConfigInfo.GetConfig().TestName);
  4. foreach (tracker item in TestConfigInfo.GetConfig().Trackers)
  5. {
  6. Console.WriteLine("Host:" + item.Host + " Port:" + item.Port);
  7. }

3.5  运行效果如下图:


4 系统appSettings配置文件单独建立配置文件

4.1 appconfig配置文件修改截图如下

4.2 system.config配置文件内容如下

4.3 调用方式和没有分开是一样的,如下

  1. Console.WriteLine("---------------------系统自带appSettings配置文件-----------------");
  2. Console.WriteLine("logLevel:" + System.Configuration.ConfigurationManager.AppSettings["logLevel"]);
  3. Console.WriteLine("LogType:" + System.Configuration.ConfigurationManager.AppSettings["LogType"]);

四、四种方式演示源码Github地址:https://github.com/lxshwyan/ConfigDemo.git

C#配置文件configSections详解的更多相关文章

  1. Nginx 主配置文件参数详解

    Nginx 主配置文件参数详解 Nginx 安装完毕后,会有响应的安装目录,安装目录里 nginx.conf 为 nginx 的主配置文件, ginx 主配置文件分为 4 部分,main(全局配置). ...

  2. CentOS网络接口配置文件ifcfg-eth详解

    ======CentOS网络接口配置文件ifcfg-eth详解====== 文件 /etc/sysconfig/network-scripts/ifcfg-eth0在/etc/sysconfig/ne ...

  3. Apache2 httpd.conf配置文件中文版详解

    Apache2 httpd.conf配置文件中文版详解## 基于 NCSA 服务的配置文件.##这是Apache服务器主要配置文件.#它包含服务器的影响服务器运行的配置指令.#参见以取得关于这些指令的 ...

  4. ssh2的application.xml配置文件配置详解

    ssh2的application.xml配置文件配置详解   1.导入其他的配置文件.在ssh项目中可以导入其他的配置文件,导入的格式为: <import resource="clas ...

  5. MySQL-5.5.32 配置文件优化详解

    目录 MySQL-5.5.32 配置文件优化详解 一.配置文件说明 2.my-medium.cnf 3.my-large.cnf 4.my-huge.cnf 5.my-innodb-heavy-4G. ...

  6. [转帖]SSH远程登录配置文件sshd_config详解

    SSH远程登录配置文件sshd_config详解 2016年06月02日 17:42:25 Field_Yang 阅读数 61386   版权声明:本文为博主原创文章,遵循CC 4.0 by-sa版权 ...

  7. mysql数据库my.ini配置文件中文详解

    mysql数据库my.ini配置文件中文详解 mysqld程序–目录和文件 basedir = path 使用给定目录作为根目录(安装目录). character-sets-dir = path 给出 ...

  8. 史上最全web.xml配置文件元素详解

    一.web.xml配置文件常用元素及其意义预览 <web-app> <!--定义了WEB应用的名字--> <display-name></display-na ...

  9. Nginx配置文件中文详解

    ######Nginx配置文件nginx.conf中文详解##### #定义Nginx运行的用户和用户组 user www www; #nginx进程数,建议设置为等于CPU总核心数. worker_ ...

随机推荐

  1. i++和++1

    概述:i++和++i 这个问题困扰了我很长时间,在这段时间里自己不止一次的怀疑自己的智商,难道自己对编程一点天赋都没有吗?此问题严重打击了我的自信心.......也曾苦苦暗自琢磨,也曾百度谷歌疯狂搜索 ...

  2. 201871010110-李华《面向对象程序设计(java)》第八周学习总结

    项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p ...

  3. nullptr与NULL

    NULL NULL can be defined as any null pointer constant. Thus existing code can retain definitions of  ...

  4. nginx 缓存配置

    nginx 缓存是可以将远程服务器上的内容缓存到本地,可以设置缓存大小,缓存时间,缓存目录等等 具体配置如下 proxy_cache_path /home/http/cache/ levels=: k ...

  5. python27期day07:基础数据类型补充、循环删除的坑、二次编码、作业题。

    1.求最大位数bit_length: a = 10 #8421 1010print(a.bit_length())结果:42.capitalize首字母变大写: s = "alex" ...

  6. 洛谷 U86501 趣味擂台

    洛谷 U86501 趣味擂台 题目传送门 题目背景 \(JDFZ\)\(2019\)秋季运动会开始辣!运动会中有一个叫做"趣味擂台"的游戏...... 题目描述 游戏内容是这样的: ...

  7. 【2019.7.25 NOIP模拟赛 T1】变换(change)(思维+大分类讨论)

    几个性质 我们通过推式子可以发现: \[B⇒AC⇒AAB⇒AAAC⇒C\] \[C⇒AB⇒AAC⇒AAAB⇒B\] 也就是说: 性质一: \(B,C\)可以相互转换. 则我们再次推式子可以发现: \[ ...

  8. coreml之通过URL加载模型

    在xcode中使用mlmodel模型,之前说的最简单的方法是将模型拖进工程中即可,xcode会自动生成有关模型的前向预测接口,这种方式非常简单,但是更新模型就很不方便. 今天说下另外一种通过URL加载 ...

  9. 4,VS常见问题解决(一闪而过、等问题)不断更新

    当然入门学c可以用VS,但是深入就不应该用VS(MSVC)编译器了,毕竟VS2017还没有完全支持C99(这个从VS2017没有实现变长数组可见) 但是想看c源码,还是 1. 推荐用 *nix系统 2 ...

  10. 关于App收集个人信息基本规范,这里公开征求你的意见!

    关于App收集个人信息基本规范,这里公开征求你的意见! https://www.thepaper.cn/newsDetail_forward_4122573 以后国家开始规范App收集个信息基本规范, ...