zoukankan      html  css  js  c++  java
  • web.config C#中使用自定义配置

    web.config C#中使用自定义配置

    <configuration>
        <configSections>     //配置节声明区域,包含配置节和命名空间声明
            <section>               //配置节声明
                <sectionGroup/>        //定义配置节组
            </section>        //配置节组中的配置节声明
        </configSections>
        <appSettings/> //预定义配置节
        <Custom element for configuration section>   //配置节设置区域
    </configuration>

    自定义配置可分为:自定义配置节和自定义配置节组。

    1. 自定义配置节

    要使用自定义配置需要修改两处地方,一是在<configSections/>中声明配置节,二是在<Custom element for configuration section>处设置配置节的具体配置。

    声明配置节语法:

    <section name="" type=""/>

    <section>:声明新配置节

    name:自定义配置节的名称

    type: 自定义配置节的类型,主要包括System.Configuration.SingleTagSectionHandler、 System.Configuration.DictionarySectionHandler、 System.Configuration.NameValueSectionHandler。

    SingleTagSectionHandler 配置节返回类型为 Systems.Collections.IDictionary
    DictionarySectionHandler 配置节返回类型为 Systems.Collections.IDictionary
    NameValueSectionHandler 配置节返回类型为 Systems.Collections.Specialized.NameValueCollection

    下面是一个完整的自定义配置节示例代码:

    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
      <configSections>
        <section name="UrlString" type="System.Configuration.SingleTagSectionHandler"/>
        <section name="UrlString2" type="System.Configuration.DictionarySectionHandler"/>
      </configSections>
      <UrlString action="add" paramString="id=1"></UrlString>
      <UrlString2>
        <add key="add" value="id=1"/>
        <add key="edit" value="id=2"/>
      </UrlString2>
    </configuration>

    程序中读取配置代码如下:

            static void Main(string[] args)
             {
                //访问 UrlString 配置节
                 IDictionary dict = ConfigurationManager.GetSection("UrlString") as IDictionary;
                 Console.WriteLine(string.Format("{0}?{1}", dict["action"], dict["paramString"]));

                //访问 UrlString2 配置节
                 IDictionary dict2 = ConfigurationManager.GetSection("UrlString2") as IDictionary;
                foreach (DictionaryEntry e in dict2)
                 {
                     Console.WriteLine(string.Format("{0}?{1}", e.Key, e.Value));
                 }

                 Console.Read();
             }

    2. 自定义配置节组

    配置节组是使用<sectionGroup>元素来声明,在配置节组中可以包括多个配置节<section>,如下:

    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
        <configSections>
            <sectionGroup name="TestGroup">
                <section name="Test" type="System.Configuration.NameValueSectionHandler"/>
            </sectionGroup>
        </configSections>
        
        <TestGroup>
            <Test>
                <add key="Hello" value="World"/>
            </Test>
        </TestGroup>
    </configuration>

    下面是访问这个配置节组的代码:

    NameValueCollection nc=(NameValueCollection)ConfigurationSettings.GetConfig("TestGroup/Test");
    MessageBox.Show(nc.AllKeys[0].ToString()+" "+nc["Hello"]);    //输出Hello World

    3. 通过 IConfigurationSectionHandler 接口实现自定义配置处理类

    IConfigurationSectionHandler 接口原型:

    public interface IConfigurationSectionHandler
    {
         Object Create(Object parent, Object configContext, XmlNode section)
    }

    Create 方法必须可由多个线程同时调用,即要保证线程安全。

    示例代码:

        public class UrlString : IConfigurationSectionHandler
         {

            private string _action;

            public string Action
             {
                get { return _action; }
                set { _action = value; }
             }

            private string _param;

            public string Param
             {
                get { return _param; }
                set { _param = value; }
             }

            #region IConfigurationSectionHandler 成员

            public object Create(object parent, object configContext, XmlNode section)
             {
                 Hashtable hashtable = new Hashtable();
                foreach (XmlAttribute attribute in section.Attributes)
                 {
                     hashtable[attribute.Name] = attribute.Value;
                 }
                return hashtable;
             }

            #endregion

            public static UrlString Create()
             {
                 UrlString us = new UrlString();
                 Hashtable ht = ConfigurationManager.GetSection("UrlString") as Hashtable;
                 us.Action = (string)ht["action"];
                 us.Param = (string)ht["paramString"];
                return us;
             }
         }
  • 相关阅读:
    【Mac + Appium + Java1.8学习(三)】之IOS自动化环境安装配置以及简单测试用例编写(模拟器、真机)
    【Mac + Appium + Java1.8学习(一)】之Android自动化环境安装配置以及IDEA配置(附录扩展Selenium+Java自动化)
    【Mac + Appium + Python3.6学习(六)】之安装Android模拟器(Genymotion)并运行模拟器进行自动化
    【Mac + Appium + Python3.6学习(五)】之常用的Android自动化测试API总结
    【Mac + Appium + Python3.6学习(四)】之常用的IOS自动化测试API总结
    【Mac + Appium + Python3.6学习(三)】之IOS自动化测试环境配置
    【Mac + Appium + Python3.6学习(二)】之Android自动化测试,appium-desktop配置和简易自动化测试脚本
    【Mac + Appium学习(一)】之安装Appium环境前提准备
    【Mac + Python3.6 + ATX基于facebook-wda】之IOS自动化(三):facebook-wda库--API学习以及附录:Github上对WDA的问题解答
    【转】【Mysql学习】之Mac上用终端使用mySQL
  • 原文地址:https://www.cnblogs.com/doosmile/p/2812781.html
Copyright © 2011-2022 走看看