1. 论坛系统升级为Xenforo,欢迎大家测试!
    排除公告

asp.net2.0如何加密数据库联接字符串

本帖由 lilcy882008-05-19 发布。版面名称:后端开发

  1. lilcy88

    lilcy88 Guest

    asp.net2.0如何加密数据库联接字符串

    在asp.net2.0中,发布网站时,加密web.config,这样可以有效保证数据库用户和密码安全,其步骤如下:

    1.添加密钥
    执行:c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pc "hnlaw" -exp
    其中"hnlaw"为密钥名称

    2.添加web.config节点
    在web.config的<configuration></configuration>之间添加:
    <configprotecteddata>
    <providers>
    <add keycontainername="hnlaw" usemachinecontainer="true" description="uses rsacryptoserviceprovider to encrypt and

    decrypt" name="hnlaw" type="system.configuration.rsaprotectedconfigurationprovider,system.configuration, version=2.0.0.0,

    culture=neutral, publickeytoken=b03f5f7f11d50a3a" />
    </providers>
    </configprotecteddata>
    注意:这里keycontainername="hnlaw"和name="hnlaw"分别表示你的密钥名称;

    3.加密web.config
    到网站根目录添加一个批处理文件enweb.bat,内容如下:
    @echo off
    c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pef "system.web/identity" "e:\hs studio\donet2\hnlawyer" -prov

    "hnlaw"
    c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pef "connectionstrings" "e:\hs studio\donet2\hnlawyer" -prov

    "hnlaw"
    pause
    注册上面的的路径和名称!
    运行后出现成功!
    4.解密
    同样到网站根目录添加一个批处理文件deweb.bat,内容如下:
    @echo off
    c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pef "system.web/identity" "e:\hs studio\donet2\hnlawyer"
    c:\windows\microsoft.net\framework\v2.0.50727\aspnet_regiis -pdf "connectionstrings" "e:\hs studio\donet2\hnlawyer"
    pause
    最后就是要注意:做完后找到c:\documents and settings\all users\application data\microsoft\crypto\rsa\machinekeys目录下,找到生成
    的密钥文件(可按时间查找),给上network service可读取权限,不然会出现error message from the provider: the rsa key container could
    not be opened.无法读取

    [​IMG]

    这样可能会出现,如果没有自己的服务器,没有权限修改machinekeys目录顺便向你推荐一款高速稳定的时代互联智强商务C型 +.CN域名,原价1952元/年,现
    价只需1588元/年,还免费送域名,CDN网站加速器 送繁简通网络简装版 ,联付宝网上支付,我觉得特值,特向大家推荐!有兴趣的朋友可

    http://www.屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词/vhost申请试试! 电话:0756-2623871 QQ: 168075865 MSN:north888@屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词
    全球免费咨询电话 http://www.屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词屏蔽词/callcenter/call.net?LineName=55