app.config文件的配置及应用
右击项目名称,选择“添加”→“添加新建项”,在出现的“添加新项”对话框中,选择“添加应用程序配置文件”;如果项目以前没有配置文件,则默认的文件名称为“app.config”,单击“确定”。出现在设计器视图中的app.config文件为:
在项目进行编译后,在bin\Debuge文件下,将出现两个配置文件(以本项目为例),一个名为“项目名称.exe.config”,另一个名为“项目名称.vshost.exe.config”。第一个文件为项目实际使用的配置文件,在程序运行中所做的更改都将被保存于此;第二个文件为原代码“app.config”的同步文件,在程序运行中不会发生更改。
在项目进行编译后,在bin\Debuge文件下,将出现两个配置文件(以本项目为例),一个名为“项目名称.exe.config”,另一个名为“项目名称.vshost.exe.config”。第一个文件为项目实际使用的配置文件,在程序运行中所做的更改都将被保存于此;第二个文件为原代码“app.config”的同步文件,在程序运行中不会发生更改。
2、connectionStrings配置节:
3、appSettings配置节:
appSettings配置节为整个程序的配置,如果是对当前用户的配置,请使用userSettings配置节,其格式与以下配置书写要求一样。
<appSettings>
5
6
7
8
9
<clear />
<addkey=
"userName"
value=
""
/>
"password"
"Department"
/>
"returnValue"
/>
"pwdPattern"
/>
"userPattern"
/>
</appSettings>
4、读取与更新app.config
对于app.config文件的读写,参照了网络文章:
http://www.codeproject.com/csharp/ SystemConfiguration.asp标题为“Read/Write App.Config File with .NET 2.0”一文。 请注意:要使用以下的代码访问app.config文件,除添加引用System.Configuration外,还必须在项目添加对System.Configuration.dll的引用。
///更新连接字符串
4.1、读取connectionStrings配置节
///<summary>
///依据连接串名字connectionName返回数据连接字符串
///</summary>
///<returns></returns>
{
connectionString =
ConfigurationManager.ConnectionStrings[connectionName].ConnectionString.ToString();
Console.WriteLine(connectionString);
return
connectionString;
}
|
4.2、更新connectionStrings配置节
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
newConString,
newProviderName)
{
bool
isModified =
false
;
//记录该连接串是否已经存在
//如果要更改的连接串已经存在
{
true
;
}
//新建一个连接字符串实例
ConnectionStringSettings mySettings =
new
ConnectionStringSettings(newName,newConString,newProviderName);
// 如果连接串已存在,首先删除它
(isModified)
{
config.ConnectionStrings.ConnectionStrings.Remove(newName);
}
config.ConnectionStrings.ConnectionStrings.Add(mySettings);
// 保存对配置文件所作的更改
// 强制重新载入配置文件的ConnectionStrings配置节
}
4.3、读取appStrings配置节
4.4、更新connectionStrings配置节
31
;
ConfigurationManager.AppSettings)
if
(key==newKey)
{
;
}
// Open App.Config of executable
// You need to remove the old settings object before you can replace it
(isModified)
{
config.AppSettings.Settings.Remove(newKey);
}
// Add an Application Setting.
config.AppSettings.Settings.Add(newKey,newValue);
// Save the changes in App.config file.
// Force a reload of a changed section.
"appSettings"
);
}