4

设想

我有一个使用 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 网络应用程序(似乎很危险)?

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

4

1 回答 1

-1

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

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

于 2015-05-10T20:44:14.910 回答