微软企业库数据库连接字串加密
2013-06-23 16:38
288 查看
« 阅读优秀代码是提高开发人员修为的一种捷径【转】
时间管理感悟 »
在发现此问题后,我看一下enterprise lib的源代码,修改了一个类后,就解决了这个问题。
该类就是ConnectionString
首先在类里面加入一个解密方法:
然后修改ConnectionString类的构造方法,增加一行代码:
此后,对数据库连接字串的加密方法是:
时间管理感悟 »
微软企业库数据库连接字串加密
在开发c/s程序的时候,如果用到了微软企业库做为数据库连接,那么就在要app.config中写入明文的数据库连接字串,这样是很不安全的。在发现此问题后,我看一下enterprise lib的源代码,修改了一个类后,就解决了这个问题。
该类就是ConnectionString
首先在类里面加入一个解密方法:
/// <summary> /// 进行DES解密。 /// </summary> /// <param name="pToDecrypt">要解密的以Base64</param> /// <param name="sKey">密钥,且必须为8位。</param> /// <returns>已解密的字符串。</returns> public string Decrypt(string pToDecrypt, string sKey) { if ((pToDecrypt.Length % 4) != 0)//因为加密后是base64,所以用4来求余进行验证 { return pToDecrypt; } if (pToDecrypt.Contains("Password"))//如果包含Password,表示没有加密 { return pToDecrypt; } byte[] inputByteArray = Convert.FromBase64String(pToDecrypt); using (DESCryptoServiceProvider des = new DESCryptoServiceProvider()) { des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); des.IV = ASCIIEncoding.ASCII.GetBytes(sKey); System.IO.MemoryStream ms = new System.IO.MemoryStream(); using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write)) { cs.Write(inputByteArray, 0, inputByteArray.Length); cs.FlushFinalBlock(); cs.Close(); } string str = Encoding.UTF8.GetString(ms.ToArray()); ms.Close(); return str; } }
然后修改ConnectionString类的构造方法,增加一行代码:
this.connectionString = Decrypt(connectionString,"abcdefgh");
此后,对数据库连接字串的加密方法是:
/// <summary> /// 进行DES加密 /// </summary> /// <param name="pToEncrypt">要加密的字符串</param> /// <param name="sKey">密钥,且必须8位</param> /// <returns>以Base64格式返回的加密字符串</returns> public string Encrypt(string pToEncrypt, string sKey) { using (DESCryptoServiceProvider des = new DESCryptoServiceProvider()) { byte[] inputByteArray = Encoding.UTF8.GetBytes(pToEncrypt); des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); des.IV = ASCIIEncoding.ASCII.GetBytes(sKey); System.IO.MemoryStream ms = new System.IO.MemoryStream(); using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write)) { cs.Write(inputByteArray, 0, inputByteArray.Length); cs.FlushFinalBlock(); cs.Close(); } string str = Convert.ToBase64String(ms.ToArray()); ms.Close(); return str; } }
相关文章推荐
- 用微软企业库加密数据库连接字符串
- 微软企业库中的动态改变连接字符串,修改后转向新的数据库查询
- 加密在 Web.Config 中存储的数据库连接字串
- 微软企业库实现连接字符串加密
- 微软企业库数据库链接文件加密(app.config||wab.config)
- bde连接加密的paradox数据库
- ADO.net 中数据库连接方式(微软提供)
- 在Spring框架下对数据库连接的配置信息加密
- W7 32 IIS 数据库连接出错,请检查连接字串
- Enterprise Library2.0中加密数据库连接字符串
- 微软企业库5.0 学习之路——第七步、Cryptographer加密模块简单分析、自定义加密接口及使用—上篇
- ADO.net 中数据库连接方式(微软提供)
- ADO.net 中数据库连接方式(微软提供)
- 【20101011-01】设置并加密App.Config中数据库连接字符串(转)
- 关于jet db access的连接字串,以及加密后的字串
- 微软企业库连接access,web.config相对路径配置
- 微软企业库4.1学习笔记(十五)缓存模块3 使用数据库作为后端存储
- ADO.net 中数据库连接方式(微软提供)
- [EntLib]微软企业库5.0 学习之路——第二步、使用VS2010+Data Access模块建立多数据库项目 [转]