c#读写App.config,ConfigurationManager.AppSettings 不生效的解决方法
我们经常会希望在程序中写入一些配置信息,例如版本号,以及数据库的连接字符串等。你可能知道在winform应用程序中可以利用properties.settings来进行类似的工作,但这些其实都利用了app.config配置文件。
本文探讨用代码的方式访问 app.config 的方法。关于 app.config 的使用远比上面提到的用途复杂,因此仅讨论最基本的 appsettings 配置节。
一、配置文件概述:
应用程序配置文件是标准的 xml 文件,xml 标记和属性是区分大小写的。它是可以按需要更改的,开发人员可以使用配置文件来更改设置,而不必重编译应用程序。配置文件的根节点是configuration。我们经常访问的是appsettings,它是由.net预定义的配置节。我们经常使用的配置文件的架构是客诉下面的形式。先大概有个印象,通过后面的实例会有一个比较清楚的认识。下面的“配置节”可以理解为进行配置一个xml的节点。
常见配置文件模式:
<configuration>
<configsections> //配置节声明区域,包含配置节和命名空间声明
<section> //配置节声明
<sectiongroup> //定义配置节组
<section> //配置节组中的配置节声明
<appsettings> //预定义配置节
<custom element for configuration section> //配置节设置区域
下面是一个最常见的应用程序配置文件的例子,只有appsettings节:
<?xml version="1.0" encoding="utf-8"?> <configuration> <appsettings> <add key="connectionstring" value="user source=.;password=;initial catalog=test;provider=sqloledb.1;" /> <add key="templatepath" value="template" /> </appsettings> </configuration>
在预定义的 appsettings 节(注意大小写),有很多的元素,这些元素名称都是“add”,有两个属性分别是“key”和“value”。
.net 提供了对appsettings节的访问方法。在 .net 1.0 和 1.1 版本中,可以使用 system.configuration.configurationsettings.appsettings["key"] 来对 key = "key" 的<add>元素的 value属性 进行访问。
注意:现在.net framework 2.0中已经明确表示此configurationsettings属性已经废弃,建议改为 configurationmanager 或 webconfigurationmanager。
使用 system.configuration.configurationmanager,需要在工程里添加对 system.configuration.dll 程序集的引用。(在解决方案管理器中右键点击工程名称,在右键菜单中选择添加引用,在.net选项卡下即可找到。)
添加引用后,就可以用 configurationmanager.appsettings["key"] 来读取对应的值了.
但是,configurationmanager.appsettings 属性是只读的,并不支持修改属性值。这是因为据说微软不太建议我们动态写入app.config文件,而是建议手工配置后,在程序运行时只做静态访问。
如果实在需要在程序中进行修改,也即写入app.config,请往下看。
二、appsettings配置节的读写操作
读取app.config文件的appsettings节的方法比较简单,可以通过上文中 system.configuration.configurationmanager.appsettings["key"]的方法进行访问,但前面也已经说了,该方法不提供写入。
如果希望写入配置文件,可以使用configurationmanager对象执行打开配置文件的操作后,将会返回一个configuration的对象,利用该对象进行操作(增删改查都可以哦)。
下面给出实现的代码(增加引用using system.configuration名称空间)
private void accessappsettings() { //获取configuration对象 configuration config = system.configuration.configurationmanager.openexeconfiguration(configurationuserlevel.none); //根据key读取<add>元素的value string name = config.appsettings.settings["name"].value; //写入<add>元素的value config.appsettings.settings["name"].value = "xieyc"; //增加<add>元素 config.appsettings.settings.add("url", "//www.jb51.net"); //删除<add>元素 config.appsettings.settings.remove("name"); //一定要记得保存,写不带参数的config.save()也可以 config.save(configurationsavemode.modified); //刷新,否则程序读取的还是之前的值(可能已装入内存) system.configuration.configurationmanager.refreshsection("appsettings"); }
需要注意的是:
1、根据并不存在的key值访问<add>元素,甚至使用remove()方法删除不存在的元素,都不会导致异常,前者会返回null。
2、add已经存在的<add>元素也不会导致异常,而是concat了已有的value和新的value,用","分隔,例如:"olldvalue,newvalue"。
3、在项目进行编译后,在运行目录bin\debuge文件下,将出现两个配置文件,一个名为“projectname.exe.config”,另一个名为“projectname.vshost.exe.config”。第一个文件为项目实际使用的配置文件,在程序运行中所做的更改都将被保存于此;第二个文件其实为原代码中“app.config”的同步文件,在程序运行中不会发生更改。
4、特别注意大小写(xml文件是区分大小写的),例如appsettings配置节。
5、可能有读者会想到,既然app.config是标准xml,当然也可以用操纵一般xml文件的方法来读写。这当然是可以的!具体可以看文末参考文献[2]和[3]中的代码,只不过我认为这样就失去了vs提供app.config文件的意义了,还不如自己定义一个配置文件方便。
本文只是粗略地讲了app.config文件中appsettings配置节的访问方法,connectionstrings配置节的操作基本是类似的,也可以自定义配置节。这些高级的用法可以自己体会,vs对app.config这个配置文件的管理还是很强大的,例如winform应用程序的settings设置(可以在ide中或者通过代码访问)其实也是利用了app.config文件。
参考资料:
[1] read/write app.config file with .net 2.0(这篇文章从.net 1.0 过渡到 2.0,因此额外讲了很多两个版本间的变化)
[2] c#读写app.config中的数据(作者不知从哪儿复制的一堆相关内容的大杂烩,也没好好整理,不过还蛮有用)
下一篇: C#二维数组基本用法实例