C# 讀寫App.config配置文件的方法

1、配置文件概述:

應用程序配置文件是標準的 XML 文件,XML 標記和屬性是區分大小寫的。它是能夠按須要更改的,開發人員可使用配置文件來更改設置,而沒必要重編譯應用程序。配置文件的根節點是configuration。咱們常常訪問的是appSettings,它是由.Net預約義的配置節。咱們常用的配置文件的架構是客訴下面的形式。先大概有個印象,經過後面的實例會有一個比較清楚的認識。下面的「配置節」能夠理解爲進行配置一個XML的節點。架構

常見配置文件模式:app

<configuration>
<configSections>                    //配置節聲明區域,包含配置節和命名空間聲明
<section>                         //配置節聲明
<sectionGroup>                //定義配置節組
<section>                        //配置節組中的配置節聲明
<appSettings>                       //預約義配置節
<Custom element for configuration section>   //配置節設置區域ide

下面是一個最多見的應用程序配置文件的例子,只有appSettings節:url

<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <appSettings>
        <add key="connectionstring" value="User Source=.;Password=123456;Initial Catalog=test;Provider=SQLOLEDB.1;" />
        <add key="TemplatePATH" value="Template" />
    </appSettings>
</configuration>    

在預約義的 appSettings 節(注意大小寫),有不少的元素,這些元素名稱都是「add」,有兩個屬性分別是「key」和「value」。spa

.NET 提供了對appSettings節的訪問方法。在 .NET 1.0 和 1.1 版本中,可使用 System.Configuration.ConfigurationSettings.AppSettings["Key"] 來對 key = "Key" 的<add>元素的 value屬性 進行訪問。.net

注意:如今.Net FrameWork 2.0中已經明確表示此ConfigurationSettings屬性已經廢棄,建議改成 ConfigurationManager 或 WebConfigurationManager。code

使用 System.Configuration.ConfigurationManager,須要在工程裏添加對 system.configuration.dll 程序集的引用。(在解決方案管理器中右鍵點擊工程名稱,在右鍵菜單中選擇添加引用,在.NET選項卡下便可找到。)orm

添加引用後,就能夠用 ConfigurationManager.AppSettings["Key"] 來讀取對應的值了.xml

可是,ConfigurationManager.AppSettings 屬性是只讀的,並不支持修改屬性值。這是由於聽說微軟不太建議咱們動態寫入app.config文件,而是建議手工配置後,在程序運行時只作靜態訪問。對象

若是實在須要在程序中進行修改,也即寫入App.Config,請往下看。

 

2、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 = "fx163";
    //增長<add>元素
    config.AppSettings.Settings.Add("url", "http://www.fx163.net");
    //刪除<add>元素
    config.AppSettings.Settings.Remove("name");
    //必定要記得保存,寫不帶參數的config.Save()也能夠
    config.Save(ConfigurationSaveMode.Modified);
    //刷新,不然程序讀取的仍是以前的值(可能已裝入內存)
    System.Configuration.ConfigurationManager.RefreshSection("appSettings");
}

須要注意的是:

一、根據並不存在的Key值訪問<add>元素,甚至使用remove()方法刪除不存在的元素,都不會致使異常,前者會返回null。

二、add已經存在的<add>元素也不會致使異常,而是concat了已有的Value和新的Value,用","分隔,例如:"olldvalue,newvalue"。

三、在項目進行編譯後,在運行目錄bin\Debuge文件下,將出現兩個配置文件,一個名爲「ProjectName.exe.config」,另外一個名爲「ProjectName.vshost.exe.config」。第一個文件爲項目實際使用的配置文件,在程序運行中所作的更改都將被保存於此;第二個文件其實爲原代碼中「App.config」的同步文件,在程序運行中不會發生更改。

四、特別注意大小寫(XML文件是區分大小寫的),例如appSettings配置節。

五、可能有讀者會想到,既然app.config是標準XML,固然也能夠用操縱通常XML文件的方法來讀寫。這固然是能夠的!只不過我認爲這樣就失去了VS提供app.config文件的意義了,還不如本身定義一個配置文件方便。

 

本文只是粗略地講了app.config文件中appSettings配置節的訪問方法,connectionStrings配置節的操做基本是相似的,也能夠自定義配置節。這些高級的用法能夠本身體會,VS對app.config這個配置文件的管理仍是很強大的,例如WinForm應用程序的Settings設置(能夠在IDE中或者經過代碼訪問)其實也是利用了app.config文件。

相關文章
相關標籤/搜索