当您使用 ADSI 兼容性位添加“脚本映射”时(使用默认网站作为参数),这会将处理程序映射添加到以下站点的 applicationHost.config 文件:
<location path="Default Web Site">
<system.webServer>
<handlers>
<add name="AboMapperCustom-12345678" ... />
</handlers>
</system>
</location>
当您在 IIS7 管理器中删除处理程序映射时,不是从 applicationHost.config 文件和上面显示的部分中删除映射,而是在站点的根目录中添加一个 web.config 文件,其中包含以下内容:
<configuration>
<system.webServer>
<handlers>
<remove name="AboMapperCustom-12345678" />
</handlers>
</system>
</configuration>
使用新的托管Microsoft.Web.Administration .NET API 获取网站配置时,您可以读取不同级别的配置,例如:
1:读取applicationHost.config或APPHOST级别的配置
ServerManager serverManager = new ServerManager();
var site = serverManager.Sites.Where(s => s.Id == 1).SingleOrDefault();
Configuration siteConfig = serverManager.GetApplicationHostConfiguration();
ConfigurationSection handlersSection =
siteConfig.GetSection("system.webServer/handlers", site.Name);
ConfigurationElementCollection handlersCollection =
handlersSection.GetCollection();
foreach (var item in handlersCollection)
{
Console.WriteLine(item.Attributes["name"].Value);
}
在上面的示例中,即使您已删除映射,它仍会在迭代处理程序映射集合时列出。这是因为您已要求在应用程序主机级别进行配置。任何存在于站点根目录或以下的 web.config 文件都不会被读取,它们的处理程序 <add/> 和 <remove/> 指令也不会被包含在内。
2:您可以读取特定于站点(或站点中的子文件夹)的配置:
ServerManager serverManager = new ServerManager();
Configuration siteConfig = serverManager.GetWebConfiguration("Default Web Site");
ConfigurationSection handlersSection =
siteConfig.GetSection("system.webServer/handlers");
ConfigurationElementCollection handlersCollection =
handlersSection.GetCollection();
foreach (var item in handlersCollection)
{
Console.WriteLine(item.Attributes["name"].Value);
}
这还将读取站点web.config 文件,并将返回一个处理程序映射列表,该列表说明web.config 中指定的<add/> 和<remove/> 指令。
这是 IIS7 管理器应用程序在您查看和修改处理程序映射时所做的事情。它通过在站点根文件夹(或子文件夹)中创建(如有必要)web.config 文件并在此级别添加必要的 <add/> 和 <remove/> 来添加和删除处理程序。
IIS6 兼容层似乎仅在 applicationHost.config APPHOST 级别(上面的选项 1)运行,这就是您看到这些差异的原因。
这是一个错误吗?我不确定这是因为最终 ADSI 从一开始就从未意识到 web.config。此外,MS 还必须添加一个新方法或标志,以允许您指定您真正希望在哪个级别进行这些“脚本映射”更改,这可能意味着破坏和测试 ADSI 组件,这反过来可能会引入错误。该行为用于模拟修改旧的 IIS6 元数据库,applicationHost.config 实际上类似于元数据库,因此您可以争论,无论对错,它都在做正确的事情。