3

运行 .NET webapp 时,我收到了一个我不知道的 EventLog 错误。

该应用程序基本上从数据库读取,然后从磁盘读取(读取文件大小,然后写回数据库)。

我已经在我的工作站(IISExpress)和我们的其他服务器(带有 IIS7 的 Windows 2008)上启动并运行了该应用程序,没有任何问题

但是当我使用 IIS6 在我们的 2003 R2 服务器上运行它时,我得到了一些奇怪的行为。IIS 应用程序启动并没有报告任何错误,但是当我尝试访问该网页时,我得到一个“服务器应用程序不可用”,并且服务器上的 EventLog 给了我这个转储:

Event Type: Error
Event Source:   ASP.NET 4.0.30319.0
Event Category: None
Event ID:   1325
Date:       24.05.2011
Time:       13:29:11
User:       N/A
Description:
Failed to initialize the AppDomain:/LM/W3SVC/1309226359/Root

Exception: System.IO.FileLoadException

Message: Could not load file or assembly 'System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' or one of its dependencies. Access is denied.

StackTrace:    at System.Reflection.RuntimeAssembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
at System.Reflection.RuntimeAssembly.nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
at System.Reflection.RuntimeAssembly.InternalLoadAssemblyName(AssemblyName assemblyRef, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection, Boolean suppressSecurityChecks)
at System.Reflection.RuntimeAssembly.InternalLoad(String assemblyString, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection)
at System.Activator.CreateInstance(String assemblyName, String typeName, Boolean ignoreCase, BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes, Evidence securityInfo, StackCrawlMark& stackMark)
at System.Activator.CreateInstance(String assemblyName, String typeName)
at System.AppDomain.CreateInstance(String assemblyName, String typeName)
at System.AppDomain.InternalCreateInstanceWithNoSecurity(String assemblyName, String typeName)
at System.AppDomain.InternalCreateInstanceWithNoSecurity(String assemblyName, String typeName)
at System.Activator.CreateInstance(AppDomain domain, String assemblyName, String typeName)
at System.Web.Hosting.ApplicationManager.CreateAppDomainWithHostingEnvironment(String appId, IApplicationHost appHost, HostingEnvironmentParameters hostingParameters)
at System.Web.Hosting.ApplicationManager.CreateAppDomainWithHostingEnvironmentAndReportErrors(String appId, IApplicationHost appHost, HostingEnvironmentParameters hostingParameters)

该应用程序继续在 IIS 中运行。这个 IIS 还托管了一大堆其他站点,没有任何问题。是的,该应用程序设置为在 .NET 4 上运行,并且服务器托管其他 .NET 4 应用程序也没有任何问题。

据我所知,它无法加载 System.Web 程序集,但我不确定这怎么可能......

这是应用程序的 web.config:

<?xml version="1.0"?>
<configuration>
    <system.web>
        <globalization culture="nb-NO"/>
        <compilation debug="true" targetFramework="4.0">
            <assemblies>
                <add assembly="System.Data.Linq, Version=4.0.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089"/>
            </assemblies>
            </compilation>
        <customErrors mode="Off"></customErrors>
        <xhtmlConformance mode="Strict"/>
        <httpRuntime requestValidationMode="2.0"/>
    </system.web>
    <system.webServer>
        <modules runAllManagedModulesForAllRequests="true"></modules>
    </system.webServer>
</configuration>
4

2 回答 2

2

这可能是由于您的 Web 应用程序文件夹中的文件系统权限不足造成的。

ASPNET我通过将和Network Service帐户Read & ExecuteList Folder Contents权限授予 web 根和所有孩子来解决相同的症状。

于 2013-07-22T03:49:11.013 回答
0

Lachlan Roche 的回答对我有用。具体来说,我将我的 Web 应用程序文件夹的完全控制权授予 LOCAL_MACHINE\Users 和 LOCAL_MACHINE\IIS_IUSRS,其中 LOCAL_MACHINE 是我的本地计算机的域。我没有检查两个组是否都需要完全访问权限,因此您可能不需要同时授予两个组的访问权限。

我的系统是带有 IIS 7.5.7600.16385 和 Visual Studio 12 的 Windows 7 Enterprise

于 2016-01-14T17:11:09.607 回答