标题:
asp.net2.0如何加密数据库联接字符串
[打印本页]
作者:
lilcy88
时间:
2008-5-28 10:41
标题:
asp.net2.0如何加密数据库联接字符串
asp.net2.0如何加密数据库联接字符串
( o- @ i; [, D+ U4 n" _- ?+ l' ^
在asp.net2.0中,发布网站时,加密web.config,这样可以有效保证数据库用户和密码安全,其步骤如下:
/ W- X. y2 a7 m3 N+ {$ Z( w6 n
1.添加密钥
9 p9 j F5 C0 l+ I1 p Y" ]" w6 h' R. @
执行:c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pc "hnlaw" -exp
# O- K& G# o% e/ e7 J: r: ^+ }
其中"hnlaw"为密钥名称
1 y% u- T4 Z4 n" y4 v
2.添加web.config节点
7 E% i. Y# C6 G& e& E" ^
在web.config的<configuration></configuration>之间添加:
r: H# _' g1 w. v
<configprotecteddata>
# S# c' ?" | K: _1 j" v
<providers>
# T" O7 h* V( S- X
<add keycontainername="hnlaw" usemachinecontainer="true" description="uses rsacryptoserviceprovider to encrypt and
& T' q) }+ b) o/ N3 p
decrypt" name="hnlaw" type="system.configuration.rsaprotectedconfigurationprovider,system.configuration, version=2.0.0.0,
- z# e1 @( U. o& {& e
culture=neutral, publickeytoken=b03f5f7f11d50a3a" />
& w! w" ^6 Q* b( d
</providers>
* B* f! O" A2 h. p+ D8 {" m
</configprotecteddata>
* d s2 k' v0 H0 Q* A
注意:这里keycontainername="hnlaw"和name="hnlaw"分别表示你的密钥名称;
s% k w- s7 ~, {3 {3 r0 d6 P
3.加密web.config
) q7 ~0 @. G, Z8 q+ ?
到网站根目录添加一个批处理文件enweb.bat,内容如下:
, v6 ?5 O& O; p
@echo off
7 }" X' `, M, s3 p W
c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pef "system.web/identity" "e:\hs studio\donet2\hnlawyer" -prov
- A" d4 M! P. i0 |; y5 P/ j: S
"hnlaw"
5 N: \7 y: L8 @' h- _
c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pef "connectionstrings" "e:\hs studio\donet2\hnlawyer" -prov
4 e2 Q' E+ [* g" m: D
"hnlaw"
+ C, Z! K; C! I5 T, D. @+ p' P
pause
" l# _4 P7 V7 I' u
注册上面的的路径和名称!
* Y1 Q! b5 }" j: ^7 q a
运行后出现成功!
0 m7 @7 i6 Y8 D+ `8 n
4.解密
+ w9 @: [9 g& t1 n9 l7 O c
同样到网站根目录添加一个批处理文件deweb.bat,内容如下:
# n+ [* E; L8 u; ^$ r1 B) f
@echo off
3 D9 w) k8 N1 l2 _0 {
c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pef "system.web/identity" "e:\hs studio\donet2\hnlawyer"
0 w H% F2 n' M3 Q" N
c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pdf "connectionstrings" "e:\hs studio\donet2\hnlawyer"
. X3 U% ~0 X7 V- p* b4 H
pause
; P( H" V1 ] s* ^
最后就是要注意:做完后找到c:\documents and settings\all users\application data\microsoft\crypto\rsa\machinekeys目录下,找到生成
' ]% s* z& h, m# n
的密钥文件(可按时间查找),给上network service可读取权限,不然会出现error message from the provider: the rsa key container could
# _8 q( l1 W0 R& j- i& N3 n" Z
not be opened.无法读取
+ Z; X% ?' I, y) @9 v( `
1 g3 S' {: o: L& d9 M8 O
这样可能会出现,如果没有自己的服务器,没有权限修改machinekeys目录顺便向你推荐一款高速稳定的时代互联智强商务C型 +.CN域名,原价1952元/年,现
' N$ ^0 I2 H+ x" c; c5 q/ z, R
价只需1588元/年,还免费送域名,CDN网站加速器 送繁简通网络简装版 ,联付宝网上支付,我觉得特值,特向大家推荐!有兴趣的朋友可
% b) B; _6 m' @# ], a
到
http://www.now.cn/vhost
申请试试! 电话:0756-2623871 QQ: 168075865 MSN:
north888@now.net.cn
3 o+ h1 R5 S0 S, u, H
全球免费咨询电话
http://www.now.cn/callcenter/call.net?LineName=55
欢迎光临 捌玖网络工作室 (http://89w.org/)
Powered by Discuz! 7.2