简单的配置信息,可以直接放入标记中。如:
< appSettings >
< add key ="LogFile" value ="d:\log\debug.log" />
< span>appSettings>
< span>configuration>
相应访问代码如下:
2. 自定义配置节(section)名称
比如,我们要使用下面的配置结构,将配置信息归类分组:
< configuration >
< myConfig >
< myDictionary >
< add key ="Area" value ="Fuzhou" />
< add key ="Device" value ="Printer" />
< add key ="Customer" value ="Muf" />
< span>myDictionary>
<myNameValue>
<add key="Area" value="Fuzhou"/>
<add key="Device" value="Printer"/>
<add key="Customer" value="Muf"/>
< span>myNameValue>
<myInfo
Area="Fuzhou" Device="Printer" Customer="Muf"
/>
< span>myConfig>
< span>configuration>
但是光这样子说明是不行的。没有声明,是不能使用自定义的配置段。我们必须要在配置文件前面加入声明:
< configSections >
< sectionGroup name ="myConfig" >
< section name ="myDictionary"
type ="System.Configuration.NameValueSectionHandler, System, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
< section name ="myNameValue"
type ="System.Configuration.DictionarySectionHandler, System, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
< section name ="myInfo"
type ="System.Configuration.SingleTagSectionHandler, System, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
< span>sectionGroup>
< span>configSections>
声明和配置的关系,示意图如下:
由图上可以看出,NameValueSectionHandler和DictionarySectionHandler在定义配置文件的内容形式上是一样的,都是用来设置内容的。只是返回到C#中的类不太一样,可以参考下面的代码示例。
另外,如果不关心Handler类的版本等信息,可以直接省略。如NameValueSectionHandler可以直接如下声明:
把上面的声明段放入配置文件中,我们的配置结构就可以正常使用了。声明中,< sectionGroup>用来定义不含配置数据的节的名称。用来定义含有自定义配置数据的节的名称。< section type>用来指定定义配置数据的类型。
注意,自定义的配置节,不能使用 System.Configuration.ConfigurationSettings.AppSettings.Get 来访问,要使用 System.Configuration.ConfigurationSettings.GetConfig。
.NET已经定义了3种配置类型:
a. NameValueSectionHandler
相应访问代码如下:
string Area = myNameValue[ " Area " ];
string Device = myNameValue[ " Device " ];
string Customer = myNameValue[ " Customer " ];
b. DictionarySectionHandler
相应访问代码如下:
string Area = myNameValue[ " Area " ];
string Device = myNameValue[ " Device " ];
string Customer = myNameValue[ " Customer " ];
c. SingleTagSectionHandler
相应访问代码如下:
string Area = myNameValue[ " Area " ];
string Device = myNameValue[ " Device " ];
string Customer = myNameValue[ " Customer " ];
这三种类型的详细信息,可以参考 MSDN 文档。同时.NET 还定义了IgnoreSectionHandler类型,为 System.Configuration 之外的系统所读取和处理的配置节提供节处理程序定义。
除此之外,.NET提供了IConfigurationSectionHandler接口,这样我们还可以自行进行扩展,以设计出我们自已的配置形式。3. 自定义配置结构 (使用IConfigurationSectionHandler)
假设有以下的配置信息,其在MyInfo可以重复许多次,那么应如何读取配置呢?这时就要使用自定义的配置程序了。
< myInfo Area ="Fuzhou" Device ="Printer" Customer ="Muf" />
< myInfo Area ="Shanghai" Device ="Mobile" Customer ="Liny" />
</ myConfig >
访问代码如下:
Debug.Assert( cfgTable.Count == 2 );
Hashtable cfgFuzhou = (Hashtable)cfgTable[ " Fuzhou " ];
Hashtable cfgShanghai = (Hashtable)cfgTable[ " Shanghai " ];
Debug.Assert( cfgFuzhou[ " Device " ] == " Printer " );
Debug.Assert( cfgShanghai[ " Device " ] == " Mobile " );
Debug.Assert( cfgFuzhou[ " Customer " ] == " Muf " );
Debug.Assert( cfgShanghai[ " Customer " ] == " Liny " );
foreach (Hashtable cfg in cfgTable.Values)
{
Console.WriteLine("Area={0} Device={1} Customer={2}", cfg["Area"], cfg["Device"], cfg["Customer"]);
}
为了能使用上面的访问代码来访问配置结构,我们需要生成一个特定的配置读取类(configurationsectionhandler),例子很简单,就不多做说明了:
{
public object Create(object parent, object configContext, System.Xml.XmlNode section)
{
Hashtable config = new Hashtable();
foreach(XmlNode node in section.ChildNodes)
{
if(node.Name != "myInfo")
throw new System.Configuration.ConfigurationException("不可识别的配置项", node);
Hashtable item = new Hashtable();
foreach(XmlAttribute attr in node.Attributes)
{
switch(attr.Name)
{
case "Area":
case "Device":
case "Customer":
item.Add(attr.Name, attr.Value);
break;
default:
throw new System.Configuration.ConfigurationException("不可识别的配置属性", attr);
}
}
config.Add(item["Area"], item);
}
return config;
}
}
然后,我们再定义配置说明。其中,mynamespace.myinfosectionhandler 是MyInfoSectionHandler类的带名字空间的完整名称;myApp 则是定义MyInfoSectionHandler类的程序集不带扩展名的名字(如myApp.dll或myApp.exe):
< configuration >
<!-- 以下是自定义配置的声明 -->
< configSections >
< section name ="myConfig" type ="myNamespace.MyInfoSectionHandler, myApp" />
</ configSections >
< myConfigs >
< myInfo Area ="Fuzhou" Device ="Printer" Customer ="Muf" />
< myInfo Area ="Shanghai" Device ="Mobile" Customer ="Liny" />
</ myConfig >
</ configuration >
根据上面的例子,我们可以使用iconfigurationsectionhandler来实现任意的配置文件结构。