C#讀寫Config配置文件案例
更新時間:2022年04月19日 08:03:17 作者:農碼一生
這篇文章介紹了C#讀寫Config配置文件的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
一、簡介
應用程序配置文件(App.config)是標準的 XML 文件,XML 標記和屬性是區(qū)分大小寫的。它是可以按需要更改的,開發(fā)人員可以使用配置文件來更改設置,而不必重編譯應用程序。
*.exe.config配置文件樣式:
<?xml version="1.0" encoding="utf-8" ?> <configuration> <connectionStrings> </connectionStrings> <appSettings> <add key="ServerIP" value="127.0.0.1"></add> <add key="DataBase" value="WarehouseDB"></add> <add key="user" value="sa"></add> <add key="password" value="sa"></add> </appSettings> <startup> <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" /> </startup> </configuration>
二、代碼
1.配置文件讀寫類
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Text.RegularExpressions; using System.Configuration; using System.ServiceModel; using System.ServiceModel.Configuration; namespace XMLDemo1 { public static class ConfigHelper { #region ConnectionStrings //依據連接串名字connectionName返回數據連接字符串 public static string GetConnectionStringsConfig(string connectionName) { //指定config文件讀取 string file = System.Windows.Forms.Application.ExecutablePath; System.Configuration.Configuration config = ConfigurationManager.OpenExeConfiguration(file); string connectionString = config.ConnectionStrings.ConnectionStrings[connectionName].ConnectionString.ToString(); return connectionString; } ///<summary> ///更新連接字符串 ///</summary> ///<param name="newName">連接字符串名稱</param> ///<param name="newConString">連接字符串內容</param> ///<param name="newProviderName">數據提供程序名稱</param> public static void UpdateConnectionStringsConfig(string newName, string newConString, string newProviderName) { //指定config文件讀取 string file = System.Windows.Forms.Application.ExecutablePath; Configuration config = ConfigurationManager.OpenExeConfiguration(file); bool exist = false; //記錄該連接串是否已經存在 //如果要更改的連接串已經存在 if (config.ConnectionStrings.ConnectionStrings[newName] != null) { exist = true; } // 如果連接串已存在,首先刪除它 if (exist) { config.ConnectionStrings.ConnectionStrings.Remove(newName); } //新建一個連接字符串實例 ConnectionStringSettings mySettings = new ConnectionStringSettings(newName, newConString, newProviderName); // 將新的連接串添加到配置文件中. config.ConnectionStrings.ConnectionStrings.Add(mySettings); // 保存對配置文件所作的更改 config.Save(ConfigurationSaveMode.Modified); // 強制重新載入配置文件的ConnectionStrings配置節(jié) ConfigurationManager.RefreshSection("ConnectionStrings"); } #endregion #region appSettings ///<summary> ///返回*.exe.config文件中appSettings配置節(jié)的value項 ///</summary> ///<param name="strKey"></param> ///<returns></returns> public static string GetAppConfig(string strKey) { //D:\Winform\xml文檔操作\XMLDemo1\bin\Debug\XMLDemo1.EXE string file = System.Windows.Forms.Application.ExecutablePath; Configuration config = ConfigurationManager.OpenExeConfiguration(file); foreach (string key in config.AppSettings.Settings.AllKeys) { if (key == strKey) { return config.AppSettings.Settings[strKey].Value.ToString(); } } return null; } ///<summary> ///在*.exe.config文件中appSettings配置節(jié)增加一對鍵值對 ///</summary> ///<param name="newKey"></param> ///<param name="newValue"></param> public static void UpdateAppConfig(string newKey, string newValue) { string file = System.Windows.Forms.Application.ExecutablePath; Configuration config = ConfigurationManager.OpenExeConfiguration(file); bool exist = false; foreach (string key in config.AppSettings.Settings.AllKeys) { if (key == newKey) { exist = true; } } if (exist) { config.AppSettings.Settings.Remove(newKey); } config.AppSettings.Settings.Add(newKey, newValue); config.Save(ConfigurationSaveMode.Modified); ConfigurationManager.RefreshSection("appSettings"); } #endregion #region // 修改system.serviceModel下所有服務終結點的IP地址 public static void UpdateServiceModelConfig(string configPath, string serverIP) { Configuration config = ConfigurationManager.OpenExeConfiguration(configPath); ConfigurationSectionGroup sec = config.SectionGroups["system.serviceModel"]; ServiceModelSectionGroup serviceModelSectionGroup = sec as ServiceModelSectionGroup; ClientSection clientSection = serviceModelSectionGroup.Client; foreach (ChannelEndpointElement item in clientSection.Endpoints) { string pattern = @"\b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b"; string address = item.Address.ToString(); string replacement = string.Format("{0}", serverIP); address = Regex.Replace(address, pattern, replacement); item.Address = new Uri(address); } config.Save(ConfigurationSaveMode.Modified); ConfigurationManager.RefreshSection("system.serviceModel"); } // 修改applicationSettings中App.Properties.Settings中服務的IP地址 public static void UpdateConfig(string configPath, string serverIP) { Configuration config = ConfigurationManager.OpenExeConfiguration(configPath); ConfigurationSectionGroup sec = config.SectionGroups["applicationSettings"]; ConfigurationSection configSection = sec.Sections["DataService.Properties.Settings"]; ClientSettingsSection clientSettingsSection = configSection as ClientSettingsSection; if (clientSettingsSection != null) { SettingElement element1 = clientSettingsSection.Settings.Get("DataService_SystemManagerWS_SystemManagerWS"); if (element1 != null) { clientSettingsSection.Settings.Remove(element1); string oldValue = element1.Value.ValueXml.InnerXml; element1.Value.ValueXml.InnerXml = GetNewIP(oldValue, serverIP); clientSettingsSection.Settings.Add(element1); } SettingElement element2 = clientSettingsSection.Settings.Get("DataService_EquipManagerWS_EquipManagerWS"); if (element2 != null) { clientSettingsSection.Settings.Remove(element2); string oldValue = element2.Value.ValueXml.InnerXml; element2.Value.ValueXml.InnerXml = GetNewIP(oldValue, serverIP); clientSettingsSection.Settings.Add(element2); } } config.Save(ConfigurationSaveMode.Modified); ConfigurationManager.RefreshSection("applicationSettings"); } private static string GetNewIP(string oldValue, string serverIP) { string pattern = @"\b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b"; string replacement = string.Format("{0}", serverIP); string newvalue = Regex.Replace(oldValue, pattern, replacement); return newvalue; } #endregion } }
2.Main 函數
namespace XMLDemo1 { class Program { static void Main(string[] args) { try { //D:\Winform\xml文檔操作\XMLDemo1\bin\Debug\XMLDemo1.EXE //string file0 = System.Windows.Forms.Application.ExecutablePath; //D:\Winform\xml文檔操作\XMLDemo1\bin\Debug\XMLDemo1.EXE.config //string file = System.Windows.Forms.Application.ExecutablePath + ".config"; //D:\Winform\xml文檔操作\XMLDemo1\bin\Debug\XMLDemo1.vshost.exe.Config //string file1 = AppDomain.CurrentDomain.SetupInformation.ConfigurationFile; string serverIP = ConfigHelper.GetAppConfig("ServerIP"); string db = ConfigHelper.GetAppConfig("DataBase"); string user = ConfigHelper.GetAppConfig("user"); string password = ConfigHelper.GetAppConfig("password"); Console.WriteLine(serverIP); Console.WriteLine(db); Console.WriteLine(user); Console.WriteLine(password); ConfigHelper.UpdateAppConfig("ServerIP", "192.168.0.1"); string newIP = ConfigHelper.GetAppConfig("ServerIP"); Console.WriteLine(newIP); ConfigHelper.UpdateConnectionStringsConfig("connstr4", ".......", "System.Data.Sqlclient"); Console.ReadKey(); } catch (Exception ex) { Console.WriteLine(ex.Message); } } } }
到此這篇關于C#讀寫Config配置文件的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
C#基于QRCode實現動態(tài)生成自定義二維碼圖片功能示例
這篇文章主要介紹了C#基于QRCode實現動態(tài)生成自定義二維碼圖片功能,結合實例形式分析了C#使用QRCode動態(tài)生成二維碼圖片相關操作技巧,需要的朋友可以參考下2019-02-02使用GetInvalidFileNameCharts生成文件名
這篇文章主要介紹了一個很實用的函數Path.GetInvalidFileNameCharts(),他可以很方便的生成一個有效的文件名稱2014-01-01C#導出生成excel文件的方法小結(xml,html方式)
C#導出生成excel文件的方法小結(xml,html方式)。需要的朋友可以過來參考下,希望對大家有所幫助2013-10-10