Board logo

标题: 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& {& eculture=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 P3.加密web.config) q7 ~0 @. G, Z8 q+ ?
到网站根目录添加一个批处理文件enweb.bat,内容如下:, v6 ?5 O& O; p
@echo off7 }" 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' Ppause
" 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 off3 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" Nc:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pdf "connectionstrings" "e:\hs  studio\donet2\hnlawyer"
. X3 U% ~0 X7 V- p* b4 Hpause
; 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" Znot 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