国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設計 > 正文

c# App.Config詳解

2019-11-17 02:47:27
字體:
供稿:網(wǎng)友

c# App.Config詳解

應用程序配置文件是標準的 xml 文件,XML 標記和屬性是區(qū)分大小寫的。它是可以按需要更改的,開發(fā)人員可以使用配置文件來更改設置,而不必重編譯應用程序。配置文件的根節(jié)點是configuration。我們經(jīng)常訪問的是appSettings,它是由.Net預定義配置節(jié)。我們經(jīng)常使用的配置文件的架構是象下面的形式。先大概有個印象,通過后面的實例會有一個比較清楚的認識。下面的“配置節(jié)”可以理解為進行配置一個XML的節(jié)點。1.向項目添加app.config文件:右擊項目名稱,選擇“添加”→“添加新建項”,在出現(xiàn)的“添加新項”對話框中,選擇“添加應用程序配置文件”;如果項目以前沒有配置文件,則默認的文件名稱為“app.config”,單擊“確定”。出現(xiàn)在設計器視圖中的app.config文件為:<?xmlversion="1.0"encoding="utf-8"?><configuration></configuration>在項目進行編譯后,在bin/Debuge文件下,將出現(xiàn)兩個配置文件(以本項目為例),一個名為“JxcManagement.EXE.config”,另一個名為“JxcManagement.vshost.exe.config”。第一個文件為項目實際使用的配置文件,在程序運行中所做的更改都將被保存于此;第二個文件為原代碼“app.config”的同步文件,在程序運行中不會發(fā)生更改。2.connectionStrings配置節(jié):請注意:如果您的SQL版本為2005 ExPRess版,則默認安裝時SQL服務器實例名為localhost/SQLExpress,須更改以下實例中“Data Source=localhost;”一句為“Data Source=localhost/SQLExpress;”,在等于號的兩邊不要加上空格。<!--數(shù)據(jù)庫連接串--> <connectionStrings> <clear/> <addname="conJxcBook"connectionString="Data Source=localhost;Initial Catalog=jxcbook;User ID=sa;passWord=********"providerName="System.Data.SqlClient"/> </connectionStrings>3.appSettings配置節(jié):appSettings配置節(jié)為整個程序的配置,如果是對當前用戶的配置,請使用userSettings配置節(jié),其格式與以下配置書寫要求一樣。<!--進銷存管理系統(tǒng)初始化需要的參數(shù)--> <appSettings> <clear/> <addkey="userName"value=""/> <addkey="password"value=""/> <addkey="Department"value=""/> <addkey="returnValue"value=""/> <addkey="pwdPattern"value=""/> <addkey="userPattern"value=""/></appSettings>4.讀取與更新app.config對于app.config文件的讀寫,參照了網(wǎng)絡文章: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配置節(jié)///<summary>///依據(jù)連接串名字connectionName返回數(shù)據(jù)連接字符串///</summary>///<param name="connectionName"></param>///<returns></returns>privatestaticstringGetConnectionStringsConfig(stringconnectionName){stringconnectionString =ConfigurationManager.ConnectionStrings[connectionName].ConnectionString.ToString();Console.WriteLine(connectionString);returnconnectionString;}4.2 更新connectionStrings配置節(jié)///<summary>///更新連接字符串///</summary>///<param name="newName">連接字符串名稱</param>///<param name="newConString">連接字符串內(nèi)容</param>///<param name="newProviderName">數(shù)據(jù)提供程序名稱</param>privatestaticvoidUpdateConnectionStringsConfig(stringnewName,stringnewConString,stringnewProviderName){boolisModified =false;//記錄該連接串是否已經(jīng)存在//如果要更改的連接串已經(jīng)存在if(ConfigurationManager.ConnectionStrings[newName] !=null) { isModified =true; }//新建一個連接字符串實例ConnectionStringSettingsmySettings =newConnectionStringSettings(newName, newConString, newProviderName);//打開可執(zhí)行的配置文件*.exe.configConfigurationconfig =ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);//如果連接串已存在,首先刪除它if(isModified) { config.ConnectionStrings.ConnectionStrings.Remove(newName); }//將新的連接串添加到配置文件中. config.ConnectionStrings.ConnectionStrings.Add(mySettings);//保存對配置文件所作的更改 config.Save(ConfigurationSaveMode.Modified);//強制重新載入配置文件的ConnectionStrings配置節(jié)ConfigurationManager.RefreshSection("ConnectionStrings");}4.3 讀取appStrings配置節(jié)///<summary>///返回*.exe.config文件中appSettings配置節(jié)的value項///</summary>///<param name="strKey"></param>///<returns></returns>privatestaticstringGetAppConfig(stringstrKey){foreach(stringkeyinConfigurationManager.AppSettings) {if(key == strKey) {returnConfigurationManager.AppSettings[strKey]; } }returnnull;}4.4 更新connectionStrings配置節(jié)///<summary>///在*.exe.config文件中appSettings配置節(jié)增加一對鍵、值對///</summary>///<param name="newKey"></param>///<param name="newValue"></param>privatestaticvoidUpdateAppConfig(stringnewKey,stringnewValue){boolisModified =false;foreach(stringkeyinConfigurationManager.AppSettings) {if(key==newKey) { isModified =true; } }// Open App.Config of executableConfigurationconfig =ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);// You need to remove the old settings object before you can replace itif(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中的數(shù)據(jù)

讀語句:

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

寫語句:

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

配置文件內(nèi)容格式:(app.config)

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

紅筆標明的幾個關鍵節(jié)是必須的

System.Configuration.ConfigurationSettings.AppSettings["Key"];

  但是現(xiàn)在FrameWork2.0已經(jīng)明確表示此屬性已經(jīng)過時。并建議改為ConfigurationManager

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

  但是要想調(diào)用ConfigurationManager必須要先在工程里添加system.configuration.dll程序集的引用。

(在解決方案管理器中右鍵點擊工程名稱,在右鍵菜單中選擇添加引用,.net TablePage下即可找到)添加引用后可以用 String str = ConfigurationManager.AppSettings["Key"]來獲取對應的值了。

  更新配置文件:

Configuration cfa = ConfigurationManager.    OpenExeConfiguration(ConfigurationUserLevel.None);cfa.AppSettings.Settings.Add("key", "Name")||   cfa.AppSettings.Settings["BrowseDir"].Value = "name";

  等等...  最后調(diào)用  cfa.Save();  當前的配置文件更新成功。

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

讀寫配置文件app.config  在.Net中提供了配置文件,讓我們可以很方面的處理配置信息,這個配置是XML格式的。而且.Net中已經(jīng)提供了一些訪問這個文件的功能。

1、讀取配置信息  下面是一個配置文件的具體內(nèi)容:

<?xml version="1.0" encoding="utf-8"?><configuration><appSettings> <add key="ConnenctionString" value="*" /> <add key="TmpPath" value="C:/Temp" /> </appSettings></configuration>

.net提供了可以直接訪問<appsettings>(注意大小寫)元素的方法,在這元素中有很多的子元素,這些子元素名稱都是 “add”,有兩個屬性分別是“key”和“value”。一般情況下我們可以將自己的配置信息寫在這個區(qū)域中,通過下面的方式進行訪問:

string ConString=System.Configuration    .ConfigurationSettings.AppSettings["ConnenctionString"];在appsettings后面的是子元素的key屬性的值,例如appsettings["connenctionstring"],我們就是訪 問<add key="ConnenctionString" value="*" />這個子元素,它的返回值就是“*”,即value屬性的值。

2、設置配置信息

  如果配置信息是靜態(tài)的,我們可以手工配置,要注意格式。如果配置信息是動態(tài)的,就需要我們寫程序來實現(xiàn)。在.Net中沒有寫配置文件的功能,我們可以使用操作XML文件的方式來操作配置文件。下面就是一個寫配置文件的例子。

private void SaveConfig(string ConnenctionString){  XmlDocument doc=new XmlDocument();  //獲得配置文件的全路徑  string 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["key"];    //根據(jù)元素的第一個屬性來判斷當前的元素是不是目標元素    if (att.Value=="ConnectionString")     {      //對目標元素中的第二個屬性賦值      att=nodes[i].Attributes["value"];      att.Value=ConnenctionString;      break;    }  }  //保存上面的修改  doc.Save(strFileName);}讀取并修改App.config文件1.向項目添加app.config文件:右擊項目名稱,選擇“添加”→“添加新建項”,在出現(xiàn)的“添加新項”對話框中,選擇“添加應用程序配置文件”;如果項目以前沒有配置文件,則默認的文件名稱為“app.config”,單擊“確定”。出現(xiàn)在設計器視圖中的app.config文件為:<?xmlversion="1.0"encoding="utf-8"?><configuration></configuration>在項目進行編譯后,在bin/Debuge文件下,將出現(xiàn)兩個配置文件(以本項目為例),一個名為“JxcManagement.EXE.config”,另一個名為“JxcManagement.vshost.exe.config”。第一個文件為項目實際使用的配置文件,在程序運行中所做的更改都將被保存于此;第二個文件為原代碼“app.config”的同步文件,在程序運行中不會發(fā)生更改。2.connectionStrings配置節(jié):請注意:如果您的SQL版本為2005 Express版,則默認安裝時SQL服務器實例名為localhost/SQLExpress,須更改以下實例中“Data Source=localhost;”一句為“Data Source=localhost/SQLExpress;”,在等于號的兩邊不要
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 利辛县| 东乌珠穆沁旗| 和林格尔县| 曲周县| 鄂托克前旗| 罗定市| 珲春市| 巴彦县| 唐河县| 鲁山县| 成武县| 沅陵县| 巴塘县| 青神县| 鄱阳县| 金堂县| 潜江市| 鄂托克旗| 皮山县| 禹州市| 乐清市| 平阳县| 哈密市| 富锦市| 类乌齐县| 湘潭市| 荔波县| 孝昌县| 南阳市| 交口县| 方城县| 绩溪县| 高陵县| 杂多县| 汉中市| 杭州市| 普安县| 磴口县| 洛隆县| 贺兰县| 永清县|