简单介绍App.config
App.config文件一般是存放数据库连接字符串的。
下面来简单介绍一下App.config文件的修改和更新。
1, 向项目添加app.config文件
右击项目名称,选择“添加”→“添加新建项”,在出现的“添加新项”对话框中,选择“添加应用程序配置文件”;如果项目以前没有配置文件,则默认的文件名称为“app.config”,单击“确定”。出现在设计器视图中的app.config文件为:
1 <?xml version="1.0" encoding="utf-8" ?> 2 <configuration> 3 </configuration>
注意:在项目进行编译后,在bin\Debuge文件下,将出现两个配置文件,一个名为“Test.exe.config”,另一个名为“Test.vshost.exe.config”。第一个文件为项目实际使用的配置文件,在程序运行中所做的更改都将被保存于此;第二个文件为原代码“app.config”的同步文件,在程序运行中不会发生更改。
2, connectionStrings配置节:
下面添加第一个connectionStrings, code 如下:
1 <connectionStrings> 2 <clear/> 3 <add name="connect" connectionString="Data Source=localhost;Initial Catalog=test;User ID=sa;password=********"/> 4 </connectionStrings>
3, appSettings配置节:
appSettings配置节为整个程序的配置,如果是对当前用户的配置,请使用userSettings配置节,其格式与以下配置书写要求一样。
1 <appSettings> 2 <add key="DownloadPath" value="" /> 3 <add key="ClientSettingsProvider.ServiceUri" value="" /> 4 </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配置节
1 ///<summary> 2 ///依据连接串名字connectionName返回数据连接字符串 3 ///</summary> 4 ///<param name="connectionName">连接串名字</param> 5 ///<returns></returns> 6 private static string GetConnectionStringsConfig(string connectionName) 7 { 8 string connectionString = 9 ConfigurationManager.ConnectionStrings[connectionName].ConnectionString.ToString(); 10 return connectionString; 11 }
4.2 更新connectionStrings配置节
1 ///<summary> 2 ///更新连接字符串 3 ///</summary> 4 ///<param name="newName">连接字符串名称</param> 5 ///<param name="newConString">连接字符串内容</param> 6 ///<param name="newProviderName">数据提供程序名称</param> 7 private static void UpdateConnectionStringsConfig(string newName, 8 string newConString, 9 string newProviderName) 10 { 11 bool isModified = false; //记录该连接串是否已经存在 12 //如果要更改的连接串已经存在 13 if (ConfigurationManager.ConnectionStrings[newName] != null) 14 { 15 isModified = true; 16 } 17 //新建一个连接字符串实例 18 ConnectionStringSettings mySettings = 19 new ConnectionStringSettings(newName, newConString, newProviderName); 20 // 打开可执行的配置文件*.exe.config 21 Configuration config = 22 ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); 23 // 如果连接串已存在,首先删除它 24 if (isModified) 25 { 26 config.ConnectionStrings.ConnectionStrings.Remove(newName); 27 } 28 // 将新的连接串添加到配置文件中. 29 config.ConnectionStrings.ConnectionStrings.Add(mySettings); 30 // 保存对配置文件所作的更改 31 config.Save(ConfigurationSaveMode.Modified); 32 // 强制重新载入配置文件的ConnectionStrings配置节 33 ConfigurationManager.RefreshSection("ConnectionStrings"); 34 }
4.3 读取appStrings配置节
///<summary> ///返回*.exe.config文件中appSettings配置节的value项 ///</summary> ///<param name="strKey"></param> ///<returns></returns> private static string GetAppConfig(string strKey) { foreach (string key in ConfigurationManager.AppSettings) { if (key == strKey) { return ConfigurationManager.AppSettings[strKey]; } } return null; }
4.4 更新connectionStrings配置节
///<summary> ///在*.exe.config文件中appSettings配置节增加一对键、值对 ///</summary> ///<param name="newKey"></param> ///<param name="newValue"></param> private static void UpdateAppConfig(string newKey, string newValue) { bool isModified = false; foreach (string key in ConfigurationManager.AppSettings) { if(key==newKey) { isModified = true; } } // Open App.Config of executable Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); // You need to remove the old settings object before you can replace it if (isModified) { config.AppSettings.Settings.Remove(newKey); } // Add an Application Setting. config.AppSettings.Settings.Add(newKey,newValue); // Save the changes in App.config file. config.Save(ConfigurationSaveMode.Modified); // Force a reload of a changed section. ConfigurationManager.RefreshSection("appSettings"); }
以上是WPF中App.config文件的更新,在这总结一下。
注意, .Net只在程序刚启动的时候,读取一次配置文件,所以我们在修改app.config文件之后,加上一行ConfigurationManager.RefreshSection("appSettings")来刷新内存中的"appSettings",这样从而实现实时更改。