ホームページ  >  記事  >  バックエンド開発  >  asp.net は構成ファイルの実装コードを読み取り、変更します

asp.net は構成ファイルの実装コードを読み取り、変更します

高洛峰
高洛峰オリジナル
2016-12-24 13:11:511256ブラウズ

app.config ファイルをプロジェクトに追加します:

プロジェクト名を右クリックし、「追加」→「新しい項目の追加」を選択し、表示される「新しい項目の追加」ダイアログボックスで「アプリケーション構成ファイルの追加」を選択します"; if プロジェクトに以前に設定ファイルがない場合、デフォルトのファイル名は「app.config」です。「OK」をクリックします。デザイナー ビューに表示される app.config ファイルは次のとおりです:
f9d9f4a8f32d97f3ef0c10742ed31240 プロジェクトがコンパイルされると、 binDebuge ファイルの下に、(このプロジェクトを例として) 2 つの構成ファイルが表示されます。1 つは「JxcManagement.EXE.config」という名前で、もう 1 つは「joucManagement.vshost.exe.config」という名前です。最初のファイルはプロジェクトで実際に使用される構成ファイルで、プログラムの実行中に行われた変更はすべてここに保存されます。2 番目のファイルは元のコード「app.config」の同期ファイルであり、実行中には発生しません。プログラムが実行中です。
2. connectionStrings 設定セクション:
注意: SQL バージョンが 2005 Express バージョンの場合、デフォルトのインストール SQL サーバー インスタンス名は、次の例の「Data Source=localhost;」に変更する必要があります。 = localhostSQLExpress;" の場合は、等号の両側にスペースを追加しないでください。
b4b8a30aff1c33639f79dd3b38a67ba5

<connectionStrings> 
<clear /> 
<addname="conJxcBook" 
connectionString="Data Source=localhost;Initial Catalog=jxcbook;User ID=sa;password=********" 
providerName="System.Data.SqlClient" /> 
</connectionStrings>

appSettings 構成セクション:
appSettings 構成セクションは、現在のユーザーの構成である場合、その userSettings 構成セクションを使用してください。フォーマットは以下の構成で記述されます。要件は同じです。

d1ed18c8546334b528ce60ad4bb19ae6

<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 ファイルの読み取りと書き込みについては、オンライン記事を参照してください。 : http://www.codeproject.com/csharp/ SystemConfiguration.asp のタイトルは「.NET 2.0 での App.Config ファイルの読み取り/書き込み」です。

注意: 次のコードを使用して 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 構成セクションを更新する

///<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"); 
}
/// <summary> 
/// 写入Key,Value 到XML文件 
/// </summary> 
/// <param name="Key"></param> 
/// <param name="Value"></param> 
public static void SaveConfig(string Key,string Value) 
{ 
XmlDocument doc = new XmlDocument(); 
//获得配置文件的全路径 
string strFileName = AppDomain.CurrentDomain.BaseDirectory.ToString() + "App.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"]; 
//根据元素的第一个属性来判断当前的元素是不是目标元素 
if (att.Value == Key) 
{ 
//对目标元素中的第二个属性赋值 
att = nodes[i].Attributes["value"]; 

att.Value = Value; 
break; 
} 
} 
//保存上面的修改 
doc.Save(strFileName); 

}

詳細 asp.net 構成ファイルの読み取りと変更実装コード関連の記事については、PHP 中国語 Web サイトに注目してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。