asp.net2.0如何加密数据库联接字符串
( `( W' P* S5 @, |, c+ w在asp.net2.0中,发布网站时,加密web.config,这样可以有效保证数据库用户和密码安全,其步骤如下:
( v# b5 E+ l3 N' `
1.添加密钥
( D/ {+ ^9 P8 C' A& S' V执行:c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pc "hnlaw" -exp
% y: d2 H0 Y( {7 S* l" w( x
其中"hnlaw"为密钥名称
3 j3 c# u" k3 P9 u; Y' x
2.添加web.config节点
) r$ r6 x+ l$ ^: E+ [" U在web.config的<configuration></configuration>之间添加:
' N- V/ r% U, u7 _<configprotecteddata>
) T3 B- `/ {9 J
<providers>
6 Q5 Z$ l4 e7 ]& Z2 U <add keycontainername="hnlaw" usemachinecontainer="true" description="uses rsacryptoserviceprovider to encrypt and
* }' @- }6 b# F/ F+ Sdecrypt" name="hnlaw" type="system.configuration.rsaprotectedconfigurationprovider,system.configuration, version=2.0.0.0,
( J* l+ u4 b! S+ j- dculture=neutral, publickeytoken=b03f5f7f11d50a3a" />
) M9 a$ n; g9 I3 f1 b5 m
</providers>
/ R3 R) q5 R1 l/ b1 m% `% j) m1 T</configprotecteddata>
0 L- _8 B$ ]+ b9 j注意:这里keycontainername="hnlaw"和name="hnlaw"分别表示你的密钥名称;
9 p: t2 J5 s6 D! f+ F
3.加密web.config
* Q9 f2 C% X+ ^( O2 H3 h W
到网站根目录添加一个批处理文件enweb.bat,内容如下:
8 ~( I7 V6 M/ ]# G' p7 c" [+ ^
@echo off
& f `' h, I8 u' i$ p' j! `
c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pef "system.web/identity" "e:\hs studio\donet2\hnlawyer" -prov
) o, ?4 S' ]) K, v8 E
"hnlaw"
6 Z5 O+ |) m& [, Y4 ^: Y( p
c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pef "connectionstrings" "e:\hs studio\donet2\hnlawyer" -prov
# l. @3 M3 o9 v% a"hnlaw"
+ t# f5 k# A9 L( r: A
pause
; a/ U( F: t. `- g) U: A2 c注册上面的的路径和名称!
- V3 }3 q2 h2 ^( d$ n0 v
运行后出现成功!
& i U- o2 A/ s7 f0 a( d. R" G
4.解密
( n& _5 A8 c- _9 x' I9 k7 d
同样到网站根目录添加一个批处理文件deweb.bat,内容如下:
: W: y# O& g2 ?, H' c
@echo off
( M% N8 [# W# E; }% Vc:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pef "system.web/identity" "e:\hs studio\donet2\hnlawyer"
- F+ }) o- ^/ Z- x6 q/ m; @2 c+ e
c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pdf "connectionstrings" "e:\hs studio\donet2\hnlawyer"
& k7 p R/ o' wpause
. T; B, ^3 [$ i: J最后就是要注意:做完后找到c:\documents and settings\all users\application data\microsoft\crypto\rsa\machinekeys目录下,找到生成
2 M% Y2 r" S& z8 P! z的密钥文件(可按时间查找),给上network service可读取权限,不然会出现error message from the provider: the rsa key container could
& i- s7 `% z' P0 [5 q
not be opened.无法读取
# k- u6 N9 |& q
* [# D& X6 h: c. [
这样可能会出现,如果没有自己的服务器,没有权限修改machinekeys目录顺便向你推荐一款高速稳定的时代互联智强商务C型 +.CN域名,原价1952元/年,现
4 g3 z* I5 P- i7 F4 V9 ?价只需1588元/年,还免费送域名,CDN网站加速器 送繁简通网络简装版 ,联付宝网上支付,我觉得特值,特向大家推荐!有兴趣的朋友可
* _( T" _. j0 \6 i+ W$ u" Z- y到
http://www.now.cn/vhost申请试试! 电话:0756-2623871 QQ: 168075865 MSN:
north888@now.net.cn3 J( ^- y8 z* L! p, B: ]
全球免费咨询电话
http://www.now.cn/callcenter/call.net?LineName=55