Asp.NET 操作配置文件

Asp.NET 操作配置文件

由于项目中多处需要对配置文件进行操作,如配置信息的读取、更改和写入,需要一个通用的类来对其进行操作和处理。这次的任务就是配置节的一些用法。

这次升级后的开发工具是基于VS2005的,分析了VS2005 新增的一些功能,它自带了一套配置文件中结点等的配置。目前的项目用的配置文件都是系统自带的,因此,这次的任务主要是对VS2005配置类的一些介绍及扩充(用户自定义配置节点的操作)。任务分为两个大方向,一个是针对Web项目(对应的配置文件为web.config),另一个是针对WinForm项目。下面的章节主要概要地介绍一下VS2005中配置项的用法

1.Web项目

1.1系统自带

在VS2005中,我们可以通过系统自带的管理类来读取和修改相应Key所对应的Value值,具体的方法如下(注意:由于key是之读属性,因此只能修改与key相对应的Value值):

传入相应的Key值(如Test),通过调用ConfigurationManager.AppSettings["Test"] .Value即可获得对应的Value值

1打开配置文件(Web.config

   Configuration config = WebConfigurationManager.OpenWebConfiguration("~");

2获取相应的appSettings配置节

 AppSettingsSection appSection = (AppSettingsSection)config.GetSection("appSettings");

3增加相应的appSettings配置节

  增加 Key – Value 的键值对(如 ”Test” – “Hello”) appSection.Settings.Add("Test", "Hello");

4保存配置节

config.Save(ConfigurationSaveMode.Modified)

1打开配置文件(Web.config

Configuration config = WebConfigurationManager.OpenWebConfiguration("~");

2传入Key值通过调用下面方法来获取对应的值

如传入Key为Test参数来获取对应值:webConfig.AppSettings.Settings["Test"].Value

3保存配置节

config.Save(ConfigurationSaveMode.Modified)

保存的构造函数有三种:

1、不带参数

2、带一个ConfigurationSaveMode参数

3、带一个ConfigurationSaveMode参数和bool型参数

ConfigurationSaveMode的参数有三种方式:

Full

将所有属性都写到配置文件。在创建信息配置文件时或将配置值从一台计算机移动到另一台计算机时最有用

Minimal

仅将不同于继承值的属性写出到配置文件。

Modified

仅将修改的属性写出到配置文件,即使值和继承值相同。

1打开配置文件(Web.config

Configuration config = WebConfigurationManager.OpenWebConfiguration("~");

2根据传入Key值来删除相应的配置节

如传入Key为Test参数来删除配置节:. webConfig.AppSettings.Settings.Remove(key);

3保存配置节

config.Save()

在VS2005中系统的配置文件允许写入两个相同key的配置节,如:

<add key ="App" value ="aaaaa"/>

<add key ="App" value ="aaaaa1"/>

读在取的时候获取的是后者的配置节信息

传入相应的name值(如Test),通过调用WebConfigurationManager.ConnectionStrings["Test"].Name即可获得对应的Name值

1打开配置文件(Web.config

   Configuration webConfig = WebConfigurationManager.OpenWebConfiguration("~");

2创建一个相应的connectionStrings配置节

ConnectionStringSettings test = new ConnectionStringSettings("test1","test1","test1.dll");

3增加相应的connectionStrings配置节

webConfig.ConnectionStrings.ConnectionStrings.Add(test);

4保存配置节

webConfig.Save()

1打开配置文件(Web.config

   Configuration webConfig = WebConfigurationManager.OpenWebConfiguration("~");

2传入name值通过调用下面方法来获取对应的值

  webConfig.ConnectionStrings.ConnectionStrings[name].ConnectionString = connectionString;

3保存配置节

webConfig.Save(ConfigurationSaveMode.Modified)

1打开配置文件(Web.config

Configuration webConfig = WebConfigurationManager.OpenWebConfiguration("~");

2根据传入name值来删除相应的配置节

webConfig.ConnectionStrings.ConnectionStrings.Remove(name);

3保存配置节

config.Save()

1.2用户自定义(configSections)

A.新建一个自定义配置节

1打开配置文件(Web.config

    Configuration webConfig = WebConfigurationManager.OpenWebConfiguration("~");

2创建一个相应的自定义配置节

SqlExample example = new SqlExample();

Example. Name = “test”;

webConfig.Sections.Add("UserSection", example as ConfigurationSection);

(注:这里的UserSection就是我们定义的配置节的名称)

3保存配置节

config.Save()

B.修改一个自定义配置节

1打开配置文件(Web.config

    Configuration webConfig = WebConfigurationManager.OpenWebConfiguration("~");

2创建一个相应的自定义配置节

webConfig.Sections.Remove("UserSection ");

SqlExample example = new SqlExample();

Example. Name = “test”;

webConfig.Sections.Add("UserSection", example as ConfigurationSection);

注:这里的UserSection就是我们定义的配置节的名称)

3保存配置节

webConfig.Save()

C.删除一个自定义配置节

1打开配置文件(Web.config

Configuration webConfig = WebConfigurationManager.OpenWebConfiguration("~");

2创建一个相应的自定义配置节

webConfig.Sections.Remove("UserSection");

(注:这里的UserSection就是我们定义的配置节的名称)

3保存配置节

webConfig.Save()

D.

由于自定义配置节的属性是只读的,因而修改实际上是将原来的配置节删除再添加上一个新的

1.3操作类

除了用户自定义的操作类外,已将appSettings和connectionStrings做好,类中的方法见帮助手册

2.WinForm项目

2.1系统自带

在VS2005中,我们可以通过系统自带的管理类来读取和修改相应Key所对应的Value值,具体的方法如下(注意:由于key是之读属性,因此只能修改与key相对应的Value值):

传入相应的Key值(如Test),通过调用ConfigurationManager.AppSettings["Test"] .Value即可获得对应的Value值

1创建一个Configuration实例

Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None)

2传入Key值通过调用下面方法来获取对应的值

如传入Key为Test参数来获取对应值:config.AppSettings.Settings["Test"].Value

3保存配置节

config.Save(ConfigurationSaveMode.Modified)

保存的构造函数有三种:

不带参数

带一个ConfigurationSaveMode参数

带一个ConfigurationSaveMode参数和bool型参数

ConfigurationSaveMode的参数有三种方式:

Full

将所有属性都写到配置文件。在创建信息配置文件时或将配置值从一台计算机移动到另一台计算机时最有用

Minimal

仅将不同于继承值的属性写出到配置文件。

Modified

仅将修改的属性写出到配置文件,即使值和继承值相同。

1打开配置文件(Web.config

Configuration config = ConfigurationManager.OpenWebConfiguration("~");

2根据传入Key值来删除相应的配置节

如传入Key为Test参数来删除配置节:. config.AppSettings.Settings.Remove(key);

3保存配置节

config.Save()

在VS2005中系统的配置文件允许写入两个相同key的配置节,如:

<add key ="App" value ="aaaaa"/>

<add key ="App" value ="aaaaa1"/>

读在取的时候获取的是后者的配置节信息

在VS2005中系统的配置文件写入两个相同key和Value的配置节,那么系统会将第二次的Value值追加第一个Value值的后面,并以逗号分隔开,如两次写入

<add key ="App" value ="aaaaa"/> 得到的结果为 <add key ="App" value ="aaaaa,aaaaa"/>

传入相应的name值(如Test),通过调用ConfigurationManager.ConnectionStrings["Test"].Name即可获得对应的Name值

1打开配置文件(Web.config

Configuration config = ConfigurationManager.OpenWebConfiguration("~");

2创建一个相应的connectionStrings配置节

ConnectionStringSettings test = new ConnectionStringSettings("test1","test1","test1.dll");

3增加相应的connectionStrings配置节

config.ConnectionStrings.ConnectionStrings.Add(test);

4保存配置节

config.Save()

1打开配置文件(Web.config

Configuration webConfig = ConfigurationManager.OpenWebConfiguration("~");

2传入name值通过调用下面方法来获取对应的值

config.ConnectionStrings.ConnectionStrings[name].ConnectionString = connectionString;

3保存配置节

config.Save(ConfigurationSaveMode.Modified)

1打开配置文件(Web.config

Configuration config = ConfigurationManager.OpenWebConfiguration("~");

2根据传入name值来删除相应的配置节

config.ConnectionStrings.ConnectionStrings.Remove(name);

3保存配置节

config.Save()

2.2用户自定义(configSections)

在VS2005中,允许用户自己来定义配置文件,具体的操作流程如下:

Configuration

在类的开头添加 System.Configuration和System.Web.Configuration的引用

[ConfigurationProperty("InfoSection")]

public string Name

{

set

{

this["InfoSection"] = value;

}

get

{

return (string)this["InfoSection"];

}

}

在红色标记的属性项一栏中,有多个参数可以设置,

Name : 属性名 (string)

DefaultValue : 该属性的缺省值 (string)

IsDefaultCollection : 指示该属性的缺省值是否为一个集合(bool)

IsKey : 指示该属性是否是一个关键属性(bool)

IsRequired : 指示该属性是否是必须的(bool)

Options : 指示该属性是否为一个元素

通常我们只要用到 Name、DefaultValue这两个参数

1打开配置文件(App.config

Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);

2创建一个相应的自定义配置节

SqlExample example = new SqlExample();

Example. Name = “test”;

config.Sections.Add("UserSection", example as ConfigurationSection);

(注:这里的UserSection就是我们定义的配置节的名称)

3保存配置节

config.Save()

3生成的配置文件的内容如下

<?xml version="1.0" encoding="utf-8"?>

<configuration>

<configSections>

<section name="DataSetting" type="Examples.DataInfo, Examples, Version=.0,   Culture=neutral, PublicKeyToken=null" />

</configSections>

<DataSetting name="This is a Test!" />

</configuration>

1打开配置文件(App.config

Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);

2创建一个相应的自定义配置节

config.Sections.Remove("UserSection ");

SqlExample example = new SqlExample();

Example. Name = “test”;

config.Sections.Add("UserSection", example as ConfigurationSection);

(注:这里的UserSection就是我们定义的配置节的名称)

3保存配置节

config.Save()

1打开配置文件(App.config

Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);

2创建一个相应的自定义配置节

config.Sections.Remove("UserSection");

(注:这里的UserSection就是我们定义的配置节的名称)

3保存配置节

config.Save()

由于自定义配置节的属性是只读的,因而修改实际上是将原来的配置节删除再添加上一个新的

2.操作类

除了用户自定义的操作类外,已将appSettings和connectionStrings做好,类中的方法见帮助手册

3.总结

如果手动写配置文件的时候有一点值得注意,就是在配置文件App.config或Web.config中写的时候如果有configSections配置节必须将其要放appSettings和connectionStrings配置节的上面

这份材料是在项目开发的时候自己总结的,若有错误之处请指出!让我们共同进步。