Enterprise Library2.0中加密数据库连接字符串

看了SHY520写的关于Data Access Application Block的文章,写得不错,忽略了一点就是如何去加密数据库连接字符串,这儿我简单的介绍一下。我们知道,在Enterprise Library1.1中加密连接字符串,需要依赖于Cryptography Application Block.NET Framework2.0中已经内置了这项功能,通过Configuration命名空间下的一些类来完成,支持两种类型的加密:

DPAPIProtectedConfigurationProvider:使用Windows Data Protection API (DPAPI)

RsaProtectedConfigurationProvider:使用RSA算法

下面来看一下具体的实现方法,假设已经有这样的一个配置文件:

None.gif <? xml version="1.0" encoding="utf-8" ?>
None.gif
None.gif
< configuration >
None.gif
None.gif  
< configSections >
None.gif
None.gif    
< section  name ="dataConfiguration"  type ="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null"   />
None.gif
None.gif  
</ configSections >
None.gif
None.gif  
< dataConfiguration  defaultDatabase ="QuickStarts"   />
None.gif
None.gif  
< connectionStrings >
None.gif
None.gif    
< add  name ="QuickStarts"  connectionString ="Database=EntLibQuickStarts;Server=RJ-097;Integrated Security=SSPI;"
None.gif
None.gif      providerName
="System.Data.SqlClient"   />
None.gif
None.gif  
</ connectionStrings >
None.gif
None.gif
</ configuration >
None.gif

1.添加对System.Configuration.dll的引用

2.在Program.cs中引入命名空间

None.gif using  System.Configuration;

3.编写相关的代码:

ExpandedBlockStart.gif ContractedBlock.gif /**/ /// <summary>
InBlock.gif
InBlock.gif
/// Author:TerryLee
InBlock.gif
InBlock.gif
/// From:http://terrylee.cnblogs.com
InBlock.gif
ExpandedBlockEnd.gif
/// </summary>

None.gif
None.gif
static   void  EncryptConfiguration()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {   
InBlock.gif    
// 使用什么类型的加密
InBlock.gif

InBlock.gif    
string provider = "RsaProtectedConfigurationProvider";
InBlock.gif
InBlock.gif    Configuration config 
= null;
InBlock.gif
InBlock.gif    config 
= ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
InBlock.gif
InBlock.gif    
// 加密连接字符串
InBlock.gif

InBlock.gif    ConfigurationSection section 
= config.ConnectionStrings;
InBlock.gif
InBlock.gif    
if ((section.SectionInformation.IsProtected == false&&
InBlock.gif
InBlock.gif        (section.ElementInformation.IsLocked 
== false))
InBlock.gif
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif      section.SectionInformation.ProtectSection(provider);
InBlock.gif
InBlock.gif        section.SectionInformation.ForceSave 
= true;
InBlock.gif
InBlock.gif        config.Save(ConfigurationSaveMode.Full);
InBlock.gif
ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}

该方法的调用放在程序的主程序的入口点:

None.gif [STAThread]
None.gif
None.gif
static   void  Main()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
// Protect the Connection Strings
InBlock.gif

InBlock.gif    EncryptConfiguration();
InBlock.gif
InBlock.gif    Application.Run(
new MainForm());
InBlock.gif
ExpandedBlockEnd.gif}

运行程序后,打开配置文件可以看到,连接字符串已经变成密文了。最后注意一点:加密的字符串在被加载到内存的时候解密。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值