1、 背景:根據項目的要求,需要對配置文件配置的數據庫連接字符串進行加密,也就是對ConnectinString節點的內容進行加密存儲,同時考慮到代碼使用連接字符串不需要進行更改,C#會自動對加密的內容進行解密。
2、需求:因此考慮單獨開發一個winform程序,對配置文件進行加密和解密,通過ConfigurationManager中的OpenMappedExeConfiguration方法創建一個Configuration對象,然后在對這個對象中的指定節點進行操作。
遇到的問題:
這個方法在當前的目錄下產生一個副本("C:\Charles2008.config.config"),而且返回的Configuration對象操作的不是Charles2008.config文件,而是程序自動創建的Charles2008.config.config文件,然而如果我把文件Charles2008.config更名為Charles2008.config.config文件或者刪除Charles2008.config文件卻提示:
參數名: exePath
3、解決方法:從網上尋找幫助,發現還真的有和我遇到一模一樣的問題,只需要在以上的代碼進行稍微一點改動即可,改動后不生成文件副本,直接操作文件,更新也是操作此文件。
ExeConfigurationFileMap fileMap = new ExeConfigurationFileMap();
fileMap.ExeConfigFilename = @" C:\Charles2008.config ";
// 再調用fileMap 實例化 config , 這樣,操作的文件就是Charles2008.config文件了,也不會產生副本文件
Configuration config = ConfigurationManager.OpenMappedExeConfiguration(fileMap, ConfigurationUserLevel.None);
4、加密連接字符串:上面技術難點解決后,根據獲取到Configuration對象Config調用以下方法即可對連接字符串進行加密。(僅針對ConectionString節點)
if (connectionSection != null)
{
connectionSection.SectionInformation.ProtectSection( " RSAProtectedConfigurationProvider ");
config.Save();
MessageBox.Show( " 保存成功! ", " 提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
5、 備注:
加密和解密在同一台計算機上使用,在加密過程中,使用了一個基於本機的密鑰。這就意味着加密和解密必須在同一台計算機上進行,否則將不能解密。同時,在一台計算機上加密的配置,在另一台計算機上將不能正常使用。
出處:http://www.cnblogs.com/Charles2008/p/ConfigurationManager_OpenMappedExeConfiguration.html