zoukankan      html  css  js  c++  java
  • 关于.net2.0中Webconfig中连接串的加密

     ASP.NET 2.0 现在允许您对配置文件的单个节进行加密,这样,几乎不可能使用文本编辑器来读取这些配置节。

    ASP.NET 包括两个内置的受保护配置提供程序:RSA 和 DPAPI DPAPI 提供程序使用特定于计算机的密钥,因此您必须在每台计算机上实际加密配置设置。默认使用的 RSA 提供程序允许您选择创建 RSA 密钥并将其安装在其他计算机上,这样您就可以在这些计算机之间复制相同的配置文件。此外,您还可以安装其他受保护配置提供程序供系统使用。

    调 用配置管理 API 可透明地使用加密的节,因为该 API 自动处理加密和解密。若要通过编程方式将配置节设置为加密的,可获取 ConfigurationSection.SectionInformation 属性,然后传入您选择的保护提供程序调用 ProtectSection 方法。若要使用默认提供程序,可以传入 null 或空字符串。UnprotectSection 方法禁用配置节的加密。

    下面的示例演示如何以编程方式对配置节进行加密,配置 API 如何自动处理加密的节。


    <%@ Import Namespace="System.Configuration" %>
    <%@ Import Namespace="System.Web.Configuration" %>
    <%@ Import Namespace="System.Xml" %>

      
    <script runat="server" language="C#">
        
        
    public void Page_Load(object source, EventArgs e)
        
    {
            
    if (!IsPostBack) {
                UpdateUI();
            }

        }


        
    void ProtectButton_OnClick(Object source, EventArgs e)
        
    {
            String path 
    = Request.CurrentExecutionFilePath;
            path 
    = path.Substring(0, path.LastIndexOf('/'));

            
    // Get configuration.
            Configuration config = WebConfigurationManager.OpenWebConfiguration(path);
            ConfigurationSection appSettings 
    = config.GetSection("appSettings");
            
    if (appSettings.SectionInformation.IsProtected) 
            
    {
                appSettings.SectionInformation.UnprotectSection();
            }

            
    else
            
    {
                appSettings.SectionInformation.ProtectSection(
    "DataProtectionConfigurationProvider");
            }


            
    try
            
    {
              config.Save();
              UpdateUI();
            }

            
    catch (Exception ex)
            
    {
              Response.Write(
    "In order to modify configuration settings, the ASP.NET process account (either the local ASPNET or Network Service account, by default) ");
              Response.Write(
    "must have write permission granted for the Web.config file in the sample directory");
            }

        }


        
    void UpdateUI()
        
    {
            String path 
    = Request.CurrentExecutionFilePath;
            path 
    = path.Substring(0, path.LastIndexOf('/'));

            
    // Get configuration.
            Configuration config = WebConfigurationManager.OpenWebConfiguration(path);

            
    // Show XML for app settings.
            ConfigurationSection appSettings = config.GetSection("appSettings");

            
    // Set protect button appropriately.
            if (appSettings.SectionInformation.IsProtected) 
            
    {
                Encrypted.Text 
    = "Yes";
                ProtectButton.Text 
    = "Unprotect";
            }

            
    else
            
    {
                Encrypted.Text 
    = "No";
                ProtectButton.Text 
    = "Protect";
            }


            
    // Show XML for app settings.
            AppSettingsXml.Text = " " + Server.HtmlEncode(appSettings.SectionInformation.GetRawXml());

            
    // Load XML directly from config file, to show encrypted XML.

            String configPath 
    = Server.MapPath("web.config");
            XmlDocument doc 
    = new XmlDocument();
            doc.PreserveWhitespace 
    = true;
            doc.Load(configPath);
            XmlNode appSettingsXml 
    = doc.SelectSingleNode("configuration/appSettings");
            AppSettingsEncrypted.Text 
    = " " + Server.HtmlEncode(appSettingsXml.OuterXml);
        }


    </script>

    <html>
     
    <head>
       
    <title>Encrypted Configuration Sections</title>
     
    </head>
      
    <body>
        
    <form id="form1" runat="server">
          
    <div>
            
    <h2>Encrypted:<asp:Label runat="server" id="Encrypted" /></h2><asp:Button runat="server" id="ProtectButton" OnClick="ProtectButton_OnClick" />
            
    <h2>Current XML (decrypted):</h2>
            
    <pre>
            
    <asp:Label runat="server" ID="AppSettingsXml" />
            
    </pre>
            
    <h2>Encrypted contents:</h2>
            
    <pre>
            
    <asp:Label runat="server" ID="AppSettingsEncrypted" />
            
    </pre>
          
    </div>
        
    </form>
      
    </body>
    </html>


    对应配置文件如下:

    <?xml version="1.0" encoding="utf-8"?>
    <configuration>
        
    <configProtectedData />
        
    <appSettings>
            
    <add key="currencyService" value="http://www.microsoft.com/services/currencyService.asmx" />
            
    <add key="creditCardValidationService" value="http://www.microsoft.com/services/cc.asmx" />
        
    </appSettings>

    </configuration>

    效果如图:

    邀月工作室

     邀月工作室

    邀月注:本文版权由邀月和博客园共同所有,转载请注明出处。
    助人等于自助!  3w@live.cn
  • 相关阅读:
    会计日历-自动生成脚本
    Oracle Key Flexfields Qualifiers
    Form Personalization应用总结
    UltraEdit (Ctrl + F) 查找、(Ctrl + R)替换功能失效
    FORM Save : ORA-01403 FRM-40735 ORA-06502
    EBS R12 Vision Profile default value
    EBS增加客制应用CUX:Custom Application
    TortoiseSVN设置比较工具为BeyondCompare
    开源的文件比较工具:WinMerge,KDiff3,diffuse
    C++ Operator Overloading
  • 原文地址:https://www.cnblogs.com/downmoon/p/1019838.html
Copyright © 2011-2022 走看看