App.Config详解及读写 *** 作

App.Config详解及读写 *** 作,第1张

概述App.Config详解读写 *** 作App.Config详解及读写 *** 作 - 大气象 - 博客园 http://greatverve.cnblogs.com/archive/2011/07/18/app-config.htmlApp.Config详解应用程序配置文件是标准的 XML 文件,XML 标记和属性 App.Config详解及读写 *** 作



App.Config详解及读写 *** 作 - 大气象 - 博客园 http://greatverve.cnblogs.com/archive/2011/07/18/app-config.HTML



App.Config详解 应用程序配置文件是标准的 XML 文件,XML 标记和属性是区分大小写的。它是可以按需要更改的,开发人员可以使用配置文件来更改设置,而不必重编译应用程序。
配置文件的根节点是configuration。我们经常访问的是appSettings,它是由.Net预定义配置节。我们经常使用的配置文件的架构是象下面的形式。
先大概有个印象,通过后面的实例会有一个比较清楚的认识。下面的“配置节”可以理解为进行配置一个XML的节点。 
1.   向项目添加  app.config  文件: 右击项目名称,选择“添加”→“添加新建项”,在出现的“添加新项”对话框中,选择“添加应用程序配置文件”;如果项目以前没有配置文件,则默认的文件名称为“  app.config  ”,单击“确定”。出现在设计器视图中的 app.config  文件为: <?  xml  version  =  "1.0 "enCoding = "utf-8 " ?> <  configuration  > </  configuration  > 在项目进行编译后,在  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;  ”,在等于号的两边不要加上空格。 <!--  数据库连接串  -->      <  connectionStrings  >          <  clear  />          <  add  name  =  "conJxcBook "                connectionString  =  "Data Source=localhost;Initial Catalog=jxcbook;User                                   ID=sa;password=******** "                provIDername  =  "System.Data.sqlClIEnt " />      </  connectionStrings  > 3. appSettings  配置节: appSettings  配置节为整个程序的配置,如果是对当前用户的配置,请使用  userSettings  配置节,其格式与以下配置书写要求一样。 <!--  进销存管理系统初始化需要的参数  -->      <  appSettings  >          <  clear  />          <  add  key  =  "username "value = "" />          <  add  key  =  "password "value = "" />          <  add  key  =  "Department "value = "" />          <  add  key  =  "returnValue "value = "" />          <  add  key  =  "pwdPattern "value = "" />          <  add  key  =  "userPattern "value = "" /> </  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配置节 @H_179_419@///  @H_179_419@<summary> @H_179_419@///  依据连接串名字connectionname返回数据连接字符串 @H_179_419@///  @H_179_419@</summary> @H_179_419@///  @H_179_419@<param name="connectionname"></param> @H_179_419@///  @H_179_419@<returns></returns> private  static string GetConnectionStringsConfig(string connectionname) { string  connectionString =         ConfigurationManager .ConnectionStrings[connectionname].ConnectionString.ToString();     Console .Writeline(connectionString);     return connectionString; } 4.2 更新connectionStrings配置节 @H_179_419@///  @H_179_419@<summary> @H_179_419@///  更新连接字符串 @H_179_419@///  @H_179_419@</summary> @H_179_419@///  @H_179_419@<param name="newname">  连接字符串名称  @H_179_419@</param> @H_179_419@///  @H_179_419@<param name="newConString">  连接字符串内容  @H_179_419@</param> @H_179_419@///  @H_179_419@<param name="newProvIDername">  数据提供程序名称  @H_179_419@</param> private  static voID UpdateConnectionStringsConfig(string newname,     string newConString,     string newProvIDername) {     bool isModifIEd = false ;    //  记录该连接串是否已经存在     //  如果要更改的连接串已经存在     if (ConfigurationManager .ConnectionStrings[newname] != null )     {         isModifIEd = true ;     }     //  新建一个连接字符串实例     ConnectionStringSettings mySettings =         new ConnectionStringSettings (newname,newConString,newProvIDername);     //  打开可执行的配置文件*.exe.config     Configuration config =         ConfigurationManager .OpenExeConfiguration(ConfigurationUserLevel .None);     //  如果连接串已存在,首先删除它     if (isModifIEd)     {         config.ConnectionStrings.ConnectionStrings.Remove(newname);     }     //  将新的连接串添加到配置文件中.     config.ConnectionStrings.ConnectionStrings.Add(mySettings);     //  保存对配置文件所作的更改     config.Save(ConfigurationSaveMode .ModifIEd);     //  强制重新载入配置文件的ConnectionStrings配置节     ConfigurationManager .RefreshSection("ConnectionStrings" ); } 4.3 读取appStrings配置节 @H_179_419@///  @H_179_419@<summary> @H_179_419@///  返回*.exe.config文件中appSettings配置节的value项 @H_179_419@///  @H_179_419@</summary> @H_179_419@///  @H_179_419@<param name="strKey"></param> @H_179_419@///  @H_179_419@<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配置节 @H_179_419@///  @H_179_419@<summary> @H_179_419@///  在*.exe.config文件中appSettings配置节增加一对键、值对 @H_179_419@///  @H_179_419@</summary> @H_179_419@///  @H_179_419@<param name="newKey"></param> @H_179_419@///  @H_179_419@<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" );

}

C#读写app.config中的数据

读语句:

               String str         =         ConfigurationManager.AppSettings[        "        DemoKey        "        ];       

 写语句:

Configuration cfa =    ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
cfa.AppSettings.Settings[ ].Value = Demovalue ;
cfa.Save();

 配置文件内容格式:(app.config)

<? xml version="1.0" enCoding="utf-8" ?>
< configuration > appSettings add key ="DemoKey" value ="*" /> </ >

 红笔标明的几个关键节是必须的

System.Configuration.ConfigurationSettings.AppSettings[ Key ];

   但是现在FrameWork2.0已经明确表示此属性已经过时。并建议改为ConfigurationManager 

或WebConfigurationManager。并且AppSettings属性是只读的,并不支持修改属性值.

  但是要想调用ConfigurationManager必须要先在工程里添加system.configuration.dll程序集的引用。

(在解决方案管理器中右键点击工程名称,在右键菜单中选择添加引用,.net tablePage下即可找到)
添加引用后可以用 String str = ConfigurationManager.AppSettings["Key"]来获取对应的值了。

  更新配置文件:

ConfigurationManager .     OpenExeConfiguration(ConfigurationUserLevel.None); cfa.AppSettings.Settings.Add( key , name ||     cfa.AppSettings.Settings[ browseDir name ;

  等等...
  最后调用
  cfa.Save(); 
  当前的配置文件更新成功。

*****************************************************************************************************************

读写配置文件app.config 
  在.Net中提供了配置文件,让我们可以很方面的处理配置信息,这个配置是XML格式的。而且.Net中已经提供了一些访问这个文件的功能。

1、读取配置信息
  下面是一个配置文件的具体内容:

xml version="1.0" enCoding="utf-8" ="ConnenctionString" ="TmpPath" ="C:\Temp" >

 .net提供了可以直接访问<appsettings>(注意大小写)元素的方法,在这元素中有很多的子元素,这些子元素名称都是 “add”,有两个属性分别是“key”和“value”。一般情况下我们可以将自己的配置信息写在这个区域中,通过下面的方式进行访问:

string ConString System.Configuration     .ConfigurationSettings.AppSettings[ ConnenctionString ]; 在appsettings后面的是子元素的key属性的值,例如appsettings["connenctionstring"],我们就是访 问<add key="ConnenctionString" value="*" />这个子元素,它的返回值就是“*”,即value属性的值。

2、设置配置信息

  如果配置信息是静态的,我们可以手工配置,要注意格式。如果配置信息是动态的,就需要我们写程序来实现。在.Net中没有写配置文件的功能,我们可以使用 *** 作XML文件的方式来 *** 作配置文件。下面就是一个写配置文件的例子。

private voID SaveConfig( ConnenctionString)
{
  Xmldocument doc
new Xmldocument();
  
// 获得配置文件的全路径    strfilename AppDomain.CurrentDomain.BaseDirectory.ToString()                     + Code.exe.config ;
  doc.LOAd(strfilename);
  
找出名称为“add”的所有元素   XmlNodeList nodes doc.GetElementsByTagname( add );
  
for ( int i = 0 ;i < nodes.Count;i ++ )
  {
    
获得将当前元素的key属性     XmlAttribute att nodes[i].Attributes[ ];
    
根据元素的第一个属性来判断当前的元素是不是目标元素      if (att.Value == ConnectionString )
    {
      
对目标元素中的第二个属性赋值       att value ];
      att.Value
ConnenctionString;
      
break ;
    }
  }
  
保存上面的修改   doc.Save(strfilename);
}
读取并修改App.config文件
1.  向项目添加 app.config 文件: 右击项目名称,选择“添加”→“添加新建项”,在出现的“添加新项”对话框中,选择“添加应用程序配置文件”;如果项目以前没有配置文件,则默认的文件名称为“ app.config ”,单击“确定”。出现在设计器视图中的 app.config 文件为: <? xml version = "1.0"enCoding="utf-8" ?> < configuration > </ configuration > 在项目进行编译后,在 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; ”,在等于号的两边不要加上空格。 <!-- 数据库连接串 -->      < connectionStrings >          < clear  />          < add name = "conJxcBook"                connectionString = "Data Source=localhost;Initial Catalog=jxcbook;User                                   ID=sa;password=********"                provIDername = "System.Data.sqlClIEnt" />      </ connectionStrings > 3. appSettings 配置节: appSettings 配置节为整个程序的配置,如果是对当前用户的配置,请使用 userSettings 配置节,其格式与以下配置书写要求一样。 <!-- 进销存管理系统初始化需要的参数 -->      < appSettings >          < clear  />          < add key = "username"value="" />          < add key = "password"value="" />          < add key = "Department"value="" />          < add key = "returnValue"value="" />          < add key = "pwdPattern"value="" />          < add key = "userPattern"value="" /> </ 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配置节 @H_179_419@/// @H_179_419@<summary> @H_179_419@/// 依据连接串名字connectionname返回数据连接字符串 @H_179_419@/// @H_179_419@</summary> @H_179_419@/// @H_179_419@<param name="connectionname"></param> @H_179_419@/// @H_179_419@<returns></returns> private  static string GetConnectionStringsConfig(string connectionname) { string  connectionString =         ConfigurationManager.ConnectionStrings[connectionname].ConnectionString.ToString();     Console.Writeline(connectionString);     return connectionString; } 4.2 更新connectionStrings配置节 @H_179_419@/// @H_179_419@<summary> @H_179_419@/// 更新连接字符串 @H_179_419@/// @H_179_419@</summary> @H_179_419@/// @H_179_419@<param name="newname"> 连接字符串名称 @H_179_419@</param> @H_179_419@/// @H_179_419@<param name="newConString"> 连接字符串内容 @H_179_419@</param> @H_179_419@/// @H_179_419@<param name="newProvIDername"> 数据提供程序名称 @H_179_419@</param> private  static voID UpdateConnectionStringsConfig(string newname,     string newConString,     string newProvIDername) {     bool isModifIEd = false;    // 记录该连接串是否已经存在     // 如果要更改的连接串已经存在     if (ConfigurationManager.ConnectionStrings[newname] != null)     {         isModifIEd = true;     }     // 新建一个连接字符串实例     ConnectionStringSettings mySettings =         new ConnectionStringSettings(newname,newProvIDername);     //  打开可执行的配置文件*.exe.config     Configuration config =         ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);     //  如果连接串已存在,首先删除它     if (isModifIEd)     {         config.ConnectionStrings.ConnectionStrings.Remove(newname);     }     //  将新的连接串添加到配置文件中.     config.ConnectionStrings.ConnectionStrings.Add(mySettings);     //  保存对配置文件所作的更改     config.Save(ConfigurationSaveMode.ModifIEd);     //  强制重新载入配置文件的ConnectionStrings配置节     ConfigurationManager.RefreshSection("ConnectionStrings"); } 4.3 读取appStrings配置节 @H_179_419@/// @H_179_419@<summary> @H_179_419@/// 返回*.exe.config文件中appSettings配置节的value项 @H_179_419@/// @H_179_419@</summary> @H_179_419@/// @H_179_419@<param name="strKey"></param> @H_179_419@/// @H_179_419@<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配置节 @H_179_419@/// @H_179_419@<summary> @H_179_419@/// 在*.exe.config文件中appSettings配置节增加一对键、值对 @H_179_419@/// @H_179_419@</summary> @H_179_419@/// @H_179_419@<param name="newKey"></param> @H_179_419@/// @H_179_419@<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"); } url: http://greatverve.cnblogs.com/archive/2011/07/18/app-config.html 总结

以上是内存溢出为你收集整理的App.Config详解及读写 *** 作全部内容,希望文章能够帮你解决App.Config详解及读写 *** 作所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1213081.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存