gpt4 book ai didi

javascript - 在 Vista 上,针对 IIS 的 ADSI 查询与 IIS 管理器不一致

转载 作者:行者123 更新时间:2023-11-28 02:58:48 24 4
gpt4 key购买 nike

使用 Vista...

我有一个使用 ADSI 在 IIS 网站上设置 ScriptMap 的脚本。它是 javascript,在 cscript.exe 中运行,代码如下所示:

var web = GetObject("IIS://localhost/W3SVC/1");
var maps = web.ScriptMaps.toArray();
map[maps.length] = ".aaa,c:\\path\\to\\isapi\\extension.dll,1,GET,POST";
web.ScriptMaps = maps.asDictionary();
web.SetInfo();

运行脚本后查看 IIS 管理器时,我可以在处理程序映射列表中看到新条目。它有一个奇怪的名称“AboMapperCustom-43155”,据我所知,它来自 ADSI 的 IIS7 兼容层。

如果在 IIS 管理器中删除这些处理程序映射,然后运行另一个 ADSI 脚本来查询 ScriptMaps 属性,则脚本中检索到的 ScriptMap 仍会列出刚刚删除的条目。 ADSI 脚本中的结果与 IIS 管理器中显示的“处理程序映射”列表不一致。

即使在启动/停止 IISADMIN 和 W3SVC 后,这种情况仍然存在。

这是预期的行为吗? ADSI 在 IIS7 中作为“兼容模式”得到支持。这是那个的神器吗?

我相信,如果处理程序映射从 IIS MANager 中删除,那么它就真的消失了,即使它仍然从 ADSI 查询中返回。

谁能对此提供任何澄清吗?

最佳答案

当您使用 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 文件,并返回一个处理程序映射列表,该列表说明了 <add/> 中指定的 <remove/>web.config 指令。

这就是当您查看和修改处理程序映射时 IIS7 管理器应用程序正在执行的操作。它通过在站点根文件夹(或子文件夹)中创建(如有必要)web.config 文件并在此级别添加必需的 <add/><remove/> 来添加和删除处理程序。

IIS6 兼容层似乎仅在 applicationHost.config APPHOST 级别(上面的选项 1)运行,这就是您看到这些差异的原因。

这是一个错误吗?我不确定这是因为最终 ADSI 从来没有意识到 web.config 。此外,MS 还必须添加一个新方法或标志,以允许您指定您真正想要在哪个级别进行这些“脚本映射”更改,这可能意味着破坏和测试 ADSI 组件,这反过来可能会引入错误。该行为是为了模拟修改旧的 IIS6 元数据库,而 applicationHost.config 实际上类似于元数据库,因此您可以认为,无论正确与否,它正在做正确的事情。

关于javascript - 在 Vista 上,针对 IIS 的 ADSI 查询与 IIS 管理器不一致,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1806820/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com