ASP.NET的Web.config文件

开发 后端
本文介绍ASP.NET的Web.config文件,以及介绍使用 RSAProtectedConfigurationProvidert和计算机级别的密钥容器进行加密的步骤。

在ASP.NET中新增了对web.config中的部分数据进行加密的功能,可以使用RSAProtectedConfigurationProvider和 DPAPIProtectedConfigurationProvider来加密,本文说明使用 RSAProtectedConfigurationProvidert和计算机级别的密钥容器进行加密的步骤。

1. 首先确定要进行加密的web.config中的配置节是否可以加密

2. 创建RSA密钥容器
 
3. 在web.config中标识要使用的密钥容器

4. 对web.config进行加密

5. 授予对 RSA 密钥容器的访问权限

首先确定要进行加密的web.config中的配置节是否可以加密

ASP.NET 2.0支持对Web.config的部分配置节进行加密,以下配置节中的数据是不能进行加密的:

  1. <processModel> 
  2. <runtime> 
  3. <mscorlib> 
  4. <startup> 
  5. <system.runtime.remoting> 
  6. <configProtectedData> 
  7. <satelliteassemblies> 
  8. <cryptographySettings> 
  9. <cryptoNameMapping> 
  10. <cryptoClasses> 

创建 RSA 密钥容器

若要创建 RSA 密钥容器,请使用 ASP.NET IIS 注册工具 (Aspnet_regiis.exe) 及 –pc 开关。必须为密钥容器指定一个名称,该名称标识应用程序的 Web.config文件的 configProtectedData 节中指定的 RsaProtectedConfigurationProvider 所使用的密钥容器。为确保可以导出新创建的 RSA 密钥容器,必须包括 -exp 选项。

例如,下面的命令创建一个名为 ABeenKeys 的 RSA 密钥容器,该容器是可导出的计算机级密钥容器。
aspnet_regiis -pc "ABeenKeys"–exp

Modify web.config to identify the key container

编辑Web.config文件以标识要使用的密钥容器
在web.config中加以<configProtectedData>来配置密钥容器, 使用名为 ABeenKeys 的计算机级 RSA 密钥容器的
在< configuration>中加入xmlns属性

  1. <configuration xmlns="http://schemas.microsoft.com/.NetConfiguration/v2.0"> 


使用名为 ABeenKeys 的计算机级 RSA 密钥容器的 saProtectedConfigurationProvider。

  1. <configProtectedData > 
  2. <providers> 
  3. <add name="ABeenProvider" 
  4. type="System.Configuration.RsaProtectedConfigurationProvider, System.
    Configuration, Version=2.0.0.0,Culture=neutral, processorArchitecture=MSIL"
     
  5. keyContainerName="ABeenKeys"/> 
  6. </providers> 
  7. </configProtectedData> 

Encrypt the <connectionStrings> section of your web.config file

加密你的web.config文件中的配置节aspnet_regiis -pe "connectionStrings" -app "/connectionTest" 

授予对 RSA 密钥容器的访问权限

可以通过以下代码确定应该给哪个用户权限
Response.Write(System.Security.Principal.WindowsIdentity.GetCurrent().Name);

默认情况下,RSA 密钥容器受到所在服务器上的 NTFS 访问控制列表 (ACL) 的严密保护。这样能够限制可以访问加密密钥的人员,从而增强加密信息的安全性。必须首先向 ASP.NET 应用程序的进程标识授予对该 RSA 密钥容器的读取访问权限,然后 ASP.NET 才能使用 RSA 密钥容器。可以使用 Aspnet_regiis.exe 工具及 -pa 开关,向 ASP.NET 应用程序的标识授予读取 RSA 密钥容器的权限。例如,下面的命令向 Windows Server 2003 NETWORK SERVICE 帐户授予对名为 ABeenKeys 的计算机级 RSA 密钥容器的读取访问权限:

aspnet_regiis -pa "ABeenKeys" "NT AUTHORITY\NETWORK SERVICE"

注意:

如果 RSA 密钥容器是用户级容器,必须以其 Windows 配置文件存储了密钥的用户的身份登录,并且必须包括 -pku 选项以授予对该用户级 RSA 密钥容器的访问权限。

若要使用计算机配置中指定的默认 RsaProtectedConfigurationProvider,必须首先向应用程序的 Windows 标识授予对名为 NetFrameworkConfigurationKey 的计算机密钥容器的访问权限,该计算机密钥容器是为该默认提供程序指定的密钥容器。例如,下面的命令向 NETWORK SERVICE 帐户授予对默认 RsaProtectedConfigurationProvider 所使用的 RSA 密钥容器的访问权限。

aspnet_regiis -pa "NetFrameworkConfigurationKey" "NT AUTHORITY\NETWORK SERVICE"

NetFrameworkConfigurationKey RSA 密钥容器是 Aspnet_regiis.exe 工具所发出的命令的默认密钥容器。因此上述命令也可以按以下方式发出:

aspnet_regiis -pa "NT AUTHORITY\NETWORK SERVICE"

【编辑推荐】

  1. ASP.NET的TypeConverter
  2. 浅析ASP.NET的TypeResolver
  3. ASP.NET中定义JavaScriptConverter
  4. 在ASP.NET中替换Sys.Services的方法
  5. 使用ASP.NET AJAX的Profile Service
责任编辑:佚名 来源: IT168
相关推荐

2009-08-05 14:11:56

ASP.NET Web

2009-07-29 14:23:08

ASP.NET配置文件

2009-07-28 14:54:47

web.config文ASP.NET应用程序

2011-04-19 14:35:58

ASP.NETWeb.config

2009-07-29 17:35:43

异常处理web.config配

2009-07-21 10:05:10

ASP.NET配置文件

2010-09-24 15:16:15

2009-07-27 17:32:39

Web ServiceASP.NET

2009-07-28 17:49:44

ASP.NET数据库连

2009-07-20 17:27:01

配置ASP.NET

2009-07-29 09:59:10

ASP.NET For

2009-08-03 17:35:07

ASP.NET WebASP.NET编程工具

2009-08-28 09:48:06

Visual Stud.NET 4Web.config

2009-07-29 17:16:47

2009-07-28 15:53:43

ASP.NET Web

2009-07-24 11:24:33

ASP.NET中文乱码

2009-07-23 15:11:43

XML Web服务方法ASP.NET

2009-07-28 16:29:06

XML Web服务ASP.NET构造

2009-07-28 17:34:28

ASP.NET XML

2009-07-29 09:38:06

Web开发ASP.NET
点赞
收藏

51CTO技术栈公众号