天天看點

C#中配置檔案的使用

1. 向項目添加app.config檔案: 右擊項目名稱,選擇“添加”→“添加建立項”,在出現的“添加新項”對話框中,選擇“添加應用程式配置檔案”;如果項目以前沒有配置檔案,則預設的檔案名稱為“app.config”,單擊“确定”。出現在設計器視圖中的app.config檔案為:

<?xmlversion="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 />   
         <addname="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配置節

///<summary>   
///依據連接配接串名字connectionName傳回資料連接配接字元串   
///</summary>   
///<param name="connectionName"></param>   
///<returns></returns>   
private static string GetConnectionStringsConfig(string connectionName)   
{   
string connectionString =    
        ConfigurationManager.ConnectionStrings[connectionName].ConnectionString.ToString();   
    Console.WriteLine(connectionString);   
    return connectionString;   
}        

4.2 更新connectionStrings配置節

///<summary>   
///更新連接配接字元串   
///</summary>   
///<param name="newName">連接配接字元串名稱</param>   
///<param name="newConString">連接配接字元串内容</param>   
///<param name="newProviderName">資料提供程式名稱</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配置節

///<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配置節

​​view plain​​​​copy to clipboard​​​​print​​​​?​​

///<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");   
}        

多層次configSections

<?xml version="1.0" encoding="utf-8" ?>

 <configuration>  

          <configSections>    

                        <section name="student" type="System.Configuration.DictionarySectionHandler"/>

          </configSections>  

          <student>    

                         <add key="name" value="http://www.cnblogs.com/i80386/archive/2011/10/27/amily"/>    

                         <add key="age" value="http://www.cnblogs.com/i80386/archive/2011/10/27/15"/>    

                         <add key="sex" value="http://www.cnblogs.com/i80386/archive/2011/10/27/female"/>  

           </student>

</configuration>

注意事項:configSections 相當于定義變量,必須放在configuration

 

下面是個例子

            IDictionary istudent = (IDictionary)ConfigurationManager.GetSection("student");     

             string[] keys=new string[istudent.Keys.Count];            

             string[] values = new string[istudent.Keys.Count];

                        istudent.Keys.CopyTo(keys,0);            

                        istudent.Values.CopyTo(values, 0);

              foreach (var key in keys){                

                                                        Console.WriteLine(key);            
                                                   }            
               foreach (var value in values) {
                                                              Console.WriteLine(value);      
                                                            }
                foreach (var key in istudent.Keys){     

                                                                     Console.WriteLine("{0}:{1}", key, istudent[key]);

                                                                 }