<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 12, comments - 6, trackbacks - 0, articles - 0
      BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
      最近在做一個(gè)WinForm的項(xiàng)目,由于采用的是在客戶端直接連接數(shù)據(jù)庫(kù)的方式,需要在客戶端部署App.config,由于使用了Enterprise Library,需要對(duì)App.config文件里的connectionStrings片斷進(jìn)行加密處理,搜索MSDN,發(fā)現(xiàn)已經(jīng)有了現(xiàn)成的工具ASP.NET IIS 注冊(cè)工具 (Aspnet_regiis.exe),可是它只能針對(duì)ASP.NET的Web.config文件,難道我們就沒(méi)有辦法了嗎?答案當(dāng)然是否定的。

    配置選項(xiàng)

    -pdf section webApplicationDirectory 對(duì)指定物理(非虛擬)目錄中的 Web.config 文件的指定配置節(jié)進(jìn)行解密。
    -pef section webApplicationDirectory 對(duì)指定物理(非虛擬)目錄中的 Web.config 文件的指定配置節(jié)進(jìn)行加密。

        -pdf 和-pef 參數(shù)是對(duì)指定的物理目錄里的Web.config文件進(jìn)行加密,我們可以先將App.config文件改名為Web.config,通過(guò)這兩個(gè)參數(shù)便可以 “騙”過(guò)系統(tǒng),讓它將指定的配置節(jié)進(jìn)行加密,我們只需要將加密后的文件名改回App.config即可,我們來(lái)實(shí)驗(yàn)一下:

        第一步:先將目錄下的App.config改名為Web.config。

        第二步:打開(kāi)SDK命令提示,輸入命令:aspnet_regiis -pef "配置節(jié)" "目錄",以我的項(xiàng)目為例,加密前的config文件內(nèi)容如下:

     1<?xml version="1.0" encoding="utf-8"?>
     2<configuration>
     3  <configSections>
     4    <section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null" />
     5  </configSections>
     6  <dataConfiguration defaultDatabase="Connection String" />
     7  <connectionStrings>
     8    <add name="Connection String" connectionString="Database=LocomotiveStat;Server=10.167.61.49;User ID=sa;Password=sa;"
     9      providerName="System.Data.SqlClient" />
    10  </connectionStrings>
    11</configuration>

        輸入命令:aspnet_regiis -pef "connectionStrings" "E:"開(kāi)發(fā)目錄",加密后的config文件內(nèi)容如下:

     1<?xml version="1.0" encoding="utf-8"?>
     2<configuration>
     3  <configSections>
     4    <section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null" />
     5  </configSections>
     6  <dataConfiguration defaultDatabase="Connection String" />
     7  <connectionStrings configProtectionProvider="RsaProtectedConfigurationProvider">
     8    <EncryptedData Type="http://www.w3.org/2001/04/xmlenc#Element"
     9      xmlns="http://www.w3.org/2001/04/xmlenc#">
    10      <EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#tripledes-cbc" />
    11      <KeyInfo xmlns="http://www.w3.org/2000/09/xmldsig#">
    12        <EncryptedKey xmlns="http://www.w3.org/2001/04/xmlenc#">
    13          <EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-1_5" />
    14          <KeyInfo xmlns="http://www.w3.org/2000/09/xmldsig#">
    15            <KeyName>Rsa Key</KeyName>
    16          </KeyInfo>
    17          <CipherData>
    18            <CipherValue>g2QFQqbHU1L6WUPYqjADqFAvHcdq/7dqCd1U9GlQFEi/nHDVHjqsWvjNywOZtQQg7Q/yW7g8xlRCo0h2+yYd/tQTNoVMu/RKdJmSjZMnmnwpWq+S2VEWK4U106JQwLCfBR/bAF4DHvG47B9KB0JbRfXBt5V2wJVaAI9u3kzuj50=</CipherValue>
    19          </CipherData>
    20        </EncryptedKey>
    21      </KeyInfo>
    22      <CipherData>
    23        <CipherValue>blwV/ZW1izFZL80YL5RkcjrIjWkQ0L1gJhgZbxEzzTgOcT24ihrAnv3/rDCG+WIZ7TL5D/rMm7dQwkIsij1Sh3befg6F3+pxcW4oe1w/bovIKuzjs3tokUpBvTTj+fsCs2W/MWUhQaWMKQWkHfS2Ajt6gL6MTYtb3pfQUp0pdHbeRxoqdiAksQ1Zzsi1FtRTi7gTT7hnpF0pJs+W9mxTVDMO/qSZXfXLOEMIs/A5ExcfvR5GjpaPuDeLuSsCN3XtjaiXzaDQ3It7j+r66+L2C0xvEhbT9SsG</CipherValue>
    24      </CipherData>
    25    </EncryptedData>
    26  </connectionStrings>
    27</configuration>

         由此可見(jiàn),我們已經(jīng)完成了任務(wù),現(xiàn)在只需要將Web.config文件名改回App.config即可,在應(yīng)用程序項(xiàng)目中無(wú)需對(duì)該文件進(jìn)行解密操作,. NET框架會(huì)自動(dòng)替我們完成,如果想解密該文件也很簡(jiǎn)單,在SDK命令提示里輸入aspnet_regiis -pdf "配置節(jié)" "目錄"即可。

    評(píng)論

    # re: 對(duì)WinForm的App.config文件進(jìn)行加密(轉(zhuǎn))  回復(fù)  更多評(píng)論   

    2007-11-29 05:27 by 歡樂(lè)的豬
    不錯(cuò)

    # re: 對(duì)WinForm的App.config文件進(jìn)行加密(轉(zhuǎn))  回復(fù)  更多評(píng)論   

    2008-08-07 20:38 by sb
    能解密 加了密又有何用?我要是用戶,一樣可以解過(guò)來(lái)看連接字串 呵呵

    # re: 對(duì)WinForm的App.config文件進(jìn)行加密(轉(zhuǎn))  回復(fù)  更多評(píng)論   

    2009-01-19 11:11 by jiajiaping
    參照樓主的方法...打開(kāi)文件后,并沒(méi)有加密啊..是什么問(wèn)題啊

    # re: 對(duì)WinForm的App.config文件進(jìn)行加密(轉(zhuǎn))  回復(fù)  更多評(píng)論   

    2009-05-19 09:19 by zhyj
    sb一般人是不會(huì)解密的,只有懂的人才可以。加密只是對(duì)一般人的低級(jí)防護(hù)措施!如果要防護(hù)高手,縱使你加密再好也無(wú)濟(jì)于事!

    只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 国产亚洲成AV人片在线观黄桃| 久久久久亚洲精品美女| 亚洲av日韩av无码| 久久精品成人免费观看| 亚洲第一成人影院| 最近免费中文在线视频| 亚洲精品**中文毛片| 国产精品亚洲玖玖玖在线观看| 8x网站免费入口在线观看| 性色av无码免费一区二区三区| 亚洲日产2021三区在线 | 亚洲午夜无码久久久久| 久久国产精品免费观看| 午夜免费国产体验区免费的| 亚洲国产一成人久久精品| 免费一级特黄特色大片在线| 国产精品永久免费| 黄页网址在线免费观看| 亚洲国产香蕉碰碰人人| 日韩激情无码免费毛片| 国产人在线成免费视频| 91香蕉在线观看免费高清| 免费无码av片在线观看| 狠狠色香婷婷久久亚洲精品| 亚洲中文字幕在线乱码| 免费午夜爽爽爽WWW视频十八禁 | 亚洲人成黄网在线观看| 亚洲福利电影在线观看| 久久精品国产亚洲AV香蕉| 亚洲va在线va天堂va不卡下载| 亚洲爆乳精品无码一区二区三区| 免费精品一区二区三区第35| jizz免费观看视频| h视频在线免费观看| 国产99久久久国产精免费| 一二三四在线观看免费中文在线观看| 欧洲乱码伦视频免费国产 | 亚洲美日韩Av中文字幕无码久久久妻妇 | aa级毛片毛片免费观看久| 亚洲中文无码永久免费| 亚洲精品白浆高清久久久久久|