找回密码
 立即注册
查看: 3817|回复: 1
打印 上一主题 下一主题

web.Config加密解密最简单实用方法

[复制链接]
跳转到指定楼层
楼主
发表于 2013-8-5 15:33:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
web.config的文件多数的时候不希望别人看到,下面提供一个加密,解密的语句,简洁方便实用,先看到效果,至于加密的原理其他的网页上做了很多说明,这里只演示效果。
  X6 [# k7 T0 r$ z# ^8 Y! U  加密前的connectionStrings节点
; h! u  X7 P  q6 z2 n+ K2 h6 J  代码
$ E% H& V3 _# x4 ~2 P+ k/ t7 `1 a3 \  <connectionStrings>
% }. X0 E- {" J+ Z+ P  t# O- p  <add name="SQLConnString1" connectionString="server=WJW-PC\SQL2008;user id=sa;password=12345;Initial Catalog=dbFASH;min pool size=4;max pool size=400;" />" [1 t4 s; o; m( e. n* |0 D
  <add name="eziyaConnectionString1" connectionString="Data Source=HOME-COMPUTER;Initial Catalog=dbFASH;Integrated Security=True;MultipleActiveResultSets=Falseacket Size=4096;Application Name=&quot;Microsoft SQL Server Management Studio&quot;"
' y# e/ B5 O- h3 B  providerName="System.Data.SqlClient" />
' ]$ I. t' n5 W/ m* U; h  <add name="eziyaConnectionString2" connectionString="Data Source=192.168.1.200;Initial Catalog=dbFASHersist Security Info=True;User ID=taoka;MultipleActiveResultSets=Falseacket Size=4096;Application Name=&quot;Microsoft SQL Server Management Studio&quot;"
  b2 S; h% ~1 d! r$ y* R. l+ U8 k1 I' q  providerName="System.Data.SqlClient" />
7 y3 [: x; q- D2 I  G0 e7 @6 _9 `  <add name="eziyaConnectionString3" connectionString="Data Source=192.168.61.160;Initial Catalog=dbFASHersist Security Info=True;User ID=sa;MultipleActiveResultSets=Falseacket Size=4096;Application Name=&quot;Microsoft SQL Server Management Studio&quot;"  F0 k# E3 F2 x0 j6 ^' c
  providerName="System.Data.SqlClient" />
: u" j3 ~! x. [; {3 r& t7 v( Z  </connectionStrings>
8 ?; |- |6 `5 r5 k! T+ Y! s  加密后的connectionStrings的节点
' }3 ?/ j: s2 Z5 B  代码: ]" M, N5 e2 h
  <connectionStrings configProtectionProvider="RsaProtectedConfigurationProvider">+ U( d( S1 Y1 y" o
  <EncryptedData Type="http://www.w3.org/2001/04/xmlenc#Element"
( c" p% k  ~) `  xmlns="http://www.w3.org/2001/04/xmlenc#"&gt;( ]' p+ k( w# p- K1 e
  <EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#tripledes-cbc" />
' G% I* {- w8 W  <KeyInfo xmlns="http://www.w3.org/2000/09/xmldsig#"&gt;
# y! \) t. {( F% i  <EncryptedKey xmlns="http://www.w3.org/2001/04/xmlenc#"&gt;2 t; r" u1 z7 k
  <EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-1_5" />
& A) f3 n) h& y  K; Z5 |% c7 Y  <KeyInfo xmlns="http://www.w3.org/2000/09/xmldsig#"&gt;
, ~4 s2 E: K& w8 q2 F  <KeyName>Rsa Key</KeyName>
) `- s% r) i; r) {  </KeyInfo>! B) r, s8 \) Y" l
  <CipherData>* l2 G4 d* D) }4 U0 m" V
  <CipherValue>FOkydQFNniZvq71ua4XapuVCUrJFOARkXeqqwyKFoP+NGXGewehxYW0zTzIn/j+YCvH/r6ABoE/AfWMMEDyr81R1mhi4ckXbiJ2BvW612/W7f7Wkqj+FDwse+lgAISHZ5HfspaY1LBvKYAu1VEm6Iu6NlT35TPnjxFf+p5Apf0E=</CipherValue>
* V; b! y, L1 t; W/ U0 L  </CipherData>/ I5 z& d! }4 z
  </EncryptedKey>. n  I$ V) A' p! u) `
  </KeyInfo>/ W3 D' K6 [. v% Q
  <CipherData># j* d. Q+ u0 @. `, n4 k
  <CipherValue>s3PKarSQ/tlnG5YcE/z/KLbnSLljw/nOj+aoafGD9eJRlZ092f5Ywx9IDRaKMqNQ6+OM3f0WOh57evnWqL8tjULwNHviMAP3RU/5CTCGfZ/k0u+jWAGYYuOxlT6/iKsMbceBGh5jmcwIG+d3itc+h+Qq5B3g8Jjbt8Y+IulmOYWEnp2xwC+Sm/IX8vjiT7jlAqUeikNYXCEcakv8GmuA0DvWBX2tuR0Iyjv8fPcyo//eRDIqKKQB22F2ikbT0/42qmgBfOCoC3M4IMRLS7rVpEUu6JYNuoXPtvaKZhQZxNmE3zIlVPyBbPOd4VatPDCWWO9VivTbMMV+ekEDhohHbeFGHBlSi75FSXCMEz1O53gbg1LDC5nJvZUAU2+suQeEoumoMEYkH27J+p5H2xCOivPnQuPx+xRFT9btNWm/P8wpw7FUdxwqRh6JJbUYnpKc5unC76OXhAAYK+5cp+oISOyMMkFYvzCstKpYYYwQ/xW/v9Kx4XgmRKRht6lgBdbiTJhVTTzWwybVx1laOrvIYL5UR3XuqdVhH8rQYx2M3acTh5zvUKmeha6DsOVngWzm0NQ6jX3pQHOP43hZddg6di6lTNdhRRnSxaYcDVhB+n9scjHtGqAXCTJw9agz2En2P9hSZnzMbaS9Qdq9MoJK3h7plJWwIyPhPktA4qXYQCBVDV+aPLyPrBjsVddfnO/yJixaO2alcH8UuTPrACzzHRKn0YwtQFHt/I4/Vb7vsX2VoaFc0BrMxzYe6z/klVope9h6uOUReSbA5E7AGNPh8OaUW8GqzFY/5/N46gofk7g/W/Egz2o9YFGUbWQduh3VK2jF0xy/cbwE0qm7tI8mmlyUnGBfy7GuHK7YM32C4g3ZUsOv38kZoiHMjjHuzfS1lMPwTS6FPBS71UN8mdK58pakcZB2rqq3ysDPkgYvGs+E98j8v9P58rEXPW99uipSRvQeQXflp7DElEuqxVh29NuxJBkOaUaR1qPd2wepRH51MS6b3RlsTpGFEEBOw4/sNt90hzaSWeydleag9mo6803wC5DDp5hJAFBJH4+jiJwfKVzKFp133OfFoGy5ea8T6RruIVMiQRWCH/zCh3FuhkOwUcc25tPfeIZgAgFlmrzCg0E4pfIfHoni//x12kuwXYefJ5IUk6BizOPP2zul831o+Irx8MfWR8n64ZAHZvKfa6BXksN+0HLAsBsPzLRrppHyFMqIBuNe1iWxBM+j3PQUeN+oXJog79YoFxdd4cf1+jMZn0+ee7aOvEu4WGv3WT25FFiYLdO99uzXOPn7UTolUqmkYlYelgh5n5QmFd4WsqOt4oYE5CFadI/n/MsLpVJmJTzA+8CAD26cpuOmloyHzsEpqUWZb5lAO9jfDVu9F6SznBr0iaCkko5jw2kZw4tqRx2B+9eUNPTQGRPRVgc5stAFVf13w974sRrwCvGRSq0U/71cBSE8KSLOj/aGf2p4UBSUPRk=</CipherValue>  e9 z7 t* T5 Z/ `* x- t% z
  </CipherData>; o5 @% M) m0 y7 Y' H) D
  </EncryptedData>) Y9 z! w9 L7 ]
  </connectionStrings>9 @- ], I1 v$ y% A1 n) e- o0 V( R
  完全看不到连接的信息!
' U4 o  e" j$ P7 t6 ]# E. n  下面是两个.bat批处理文件
& B& H5 a- \; A! f1 L; l: g9 T: m3 ~  加密:! M' \* y" g0 `$ o
  @echo off* t, R! i3 y5 i8 S6 S% l% U0 M
  C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\aspnet_regiis.exe -pef "connectionStrings" "E:\code\proj\Web": s5 F+ ^. S) ]0 S9 z/ M
  解密:
& u* k5 n: A! {  Z! A7 C- F' d$ J  @echo off) z0 y! d* r7 F6 [  d/ Q
  C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\aspnet_regiis.exe -pdf "connectionStrings" "E:\code\proj\Web") L+ a2 p; [* t6 Y
  PAUSE7 @; {! r2 y3 e$ J
  直接将语句拷贝到.BAT文件中,E:\code\proj\Web为相应的web.config所在的路径,只能在一台电脑上操作,否则不可逆
回复

使用道具 举报

沙发
发表于 2013-8-5 19:31:27 | 只看该作者
好方法。我正好刚遇到这个问题
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表