gpt4 book ai didi

asp.net - 具有 2.0 应用程序池的子应用程序在具有 4.0 应用程序池的站点下运行

转载 作者:行者123 更新时间:2023-12-01 17:11:33 24 4
gpt4 key购买 nike

场景

我有一个使用 ASP.Net 4.0 构建的 IIS 站点应用程序,使用其自己的应用程序 v4.0 应用程序池运行。该网站托管的是一个使用 ASP.Net 2.0 构建的子应用程序,具有自己的应用程序池。

<site name="Intranet" id="1" serverAutoStart="true">
<application path="/" applicationPool="Site-Intranet">
<virtualDirectory path="/" physicalPath="D:\sites\intranet" />
</application>
<application path="/ChildApp" applicationPool="App-ChildApp">
<virtualDirectory path="/" physicalPath="D:\apps\childapp" />
</application>
</site>

我的第一个想法是 2.0 应用程序应该使用 v2.0 应用程序池运行。这样做时访问 URL 会导致服务器错误 - 它无法识别父站点的 web.config 编译设置中的“targetFramework”属性。

我明白原因,并找到了两种解决方案/解决方法,但我并不完全理解每一种的含义。

修复

1。将应用程序的应用程序池设置为 v4.0 .

2。将应用程序的应用程序池保留为 v2.0 ,但更改父站点的 web.config 以中断 <compilation> 上的继承部分:

<location path="." inheritInChildApplications="false">
<system.web>
<compilation targetFramework="4.0" debug="true" />
</system.web>
</location>

问题:

这些修复/解决方案到底发生了什么?

在场景 #1 中,2.0 应用程序是否由 4.0 CLR 编译/运行?假设是这样,CLR 是否尝试将其作为 2.0 应用程序运行(即向后兼容性)?或者只是假设它是一个 4.0 Web 应用程序(看起来很危险)?

在场景 #2 中,我知道我们已阻止子应用程序查看 targetFramework属性,但是 2.0 CLR 真的编译/运行应用程序吗?如果是这样,这就是在 ASP.Net 4.0 站点下安全运行 ASP.Net 2.0 应用程序所需的全部内容吗?

最佳答案

我多次使用场景#2,从未遇到过任何问题。所以是的这就是在 ASP.Net 4.0 站点下安全运行 ASP.Net 2.0 应用程序所需的全部内容。

尽管没有人可以回答您的两个应用程序一定会以这种方式协同工作。可能最好进行完整的系统测试,如果您确实发现任何特定问题,请提出新问题。

关于asp.net - 具有 2.0 应用程序池的子应用程序在具有 4.0 应用程序池的站点下运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11233852/

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