本文共 4132 字,大约阅读时间需要 13 分钟。
右击项目名称,选择“添加”→“添加新建项”,在出现的“添加新项”对话框中,选择“添加应用程序配置文件”;如果项目以前没有配置文件,则默认的文件名称为“ app.config ”,单击“确定”。出现在设计器视图中的 app.config 文件为: <? xml version = "1.0"encoding="utf-8" ?> 在项目进行编译后,在 bin/Debuge 文件下,将出现两个配置文件 ( 以本项目为例 ) ,一个名为“ JxcManagement.EXE.config ”,另一个名为“ JxcManagement.vshost.exe.config ”。第一个文件为项目实际使用的配置文件,在程序运行中所做的更改都将被保存于此;第二个文件为原代码“ app.config ”的同步文件,在程序运行中不会发生更改。 2. connectionStrings 配置节: 请注意:如果您的 SQL 版本为 2005 Express 版,则默认安装时 SQL 服务器实例名为 localhost/SQLExpress ,须更改以下实例中“ Data Source=localhost; ”一句为“ Data Source=localhost/SQLExpress; ”,在等于号的两边不要加上空格。 < add name = "conJxcBook" connectionString = "Data Source=localhost;Initial Catalog=jxcbook;User ID=sa;password=********" providerName = "System.Data.SqlClient" /> appSettings 配置节为整个程序的配置,如果是对当前用户的配置,请使用 userSettings 配置节,其格式与以下配置书写要求一样。 < add key = "userName"value="" /> < add key = "password"value="" /> < add key = "Department"value="" /> < add key = "returnValue"value="" /> < add key = "pwdPattern"value="" /> < add key = "userPattern"value="" /> 对于
app.config文件的读写,参照了网络文章: SystemConfiguration.asp标题为“Read/Write App.Config File with .NET 2.0 ”一文。
请注意:要使用以下的代码访问app.config文件,除添加引用System.Configuration外,还必须在项目添加对System.Configuration.dll的引用。
4.1 读取connectionStrings配置节
/// 依据连接串名字connectionName返回数据连接字符串 /// <param name="connectionName"></param> private static string GetConnectionStringsConfig(string connectionName) string connectionString = ConfigurationManager.ConnectionStrings[connectionName].ConnectionString.ToString(); Console.WriteLine(connectionString); 4.2 更新connectionStrings配置节
/// <param name="newName"> 连接字符串名称 </param> /// <param name="newConString"> 连接字符串内容 </param> /// <param name="newProviderName"> 数据提供程序名称 </param> private static void UpdateConnectionStringsConfig(string newName, bool isModified = false; // 记录该连接串是否已经存在 if (ConfigurationManager.ConnectionStrings[newName] != null) ConnectionStringSettings mySettings = new ConnectionStringSettings(newName, newConString, newProviderName); // 打开可执行的配置文件*.exe.config ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); config.ConnectionStrings.ConnectionStrings.Remove(newName); config.ConnectionStrings.ConnectionStrings.Add(mySettings); config.Save(ConfigurationSaveMode.Modified); // 强制重新载入配置文件的ConnectionStrings配置节 ConfigurationManager.RefreshSection("ConnectionStrings"); /// 返回*.exe.config文件中appSettings配置节的value项 /// <param name="strKey"></param> private static string GetAppConfig(string strKey) foreach (string key in ConfigurationManager.AppSettings) return ConfigurationManager.AppSettings[strKey]; 4.4 更新connectionStrings配置节
/// 在*.exe.config文件中appSettings配置节增加一对键、值对 /// <param name="newKey"></param> /// <param name="newValue"></param> private static void UpdateAppConfig(string newKey, string newValue) foreach (string key in ConfigurationManager.AppSettings) // Open App.Config of executable ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); // You need to remove the old settings object before you can replace it 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"); 转载地址:http://izupi.baihongyu.com/