"处理您的请求时发生异常.此外,执行自定义错误页面时发生了另一个异常......"

Ily*_*gan 97 asp.net-mvc web-config server-error asp.net-mvc-4

我正在尝试将MVC网站发布为Azure webrole.

当我在本地运行它时,一切正常.

但是,一旦我将它发布到Azure并浏览到一些MVC操作,我就会收到此错误:

'/'应用程序中的服务器错误.

运行时错误

描述:处理您的请求时发生异常.此外,执行第一个异常的自定义错误页面时发生另一个异常.请求已终止.

我不明白错误处理程序如何遇到异常,因为错误是以默认方式处理的:

public class FilterConfig
{
    public static void RegisterGlobalFilters(GlobalFilterCollection filters)
    {
        filters.Add(new HandleErrorAttribute());
    }
}
Run Code Online (Sandbox Code Playgroud)

这是我的web.config:

<?xml version="1.0"?>

<configuration>
  <configSections>
    <sectionGroup name="system.web.webPages.razor" type="System.Web.WebPages.Razor.Configuration.RazorWebSectionGroup, System.Web.WebPages.Razor, Version=2.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">
      <section name="host" type="System.Web.WebPages.Razor.Configuration.HostSection, System.Web.WebPages.Razor, Version=2.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" />
      <section name="pages" type="System.Web.WebPages.Razor.Configuration.RazorPagesSection, System.Web.WebPages.Razor, Version=2.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" />
    </sectionGroup>
  </configSections>

  <system.web.webPages.razor>
    <host factoryType="System.Web.Mvc.MvcWebRazorHostFactory, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
    <pages pageBaseType="System.Web.Mvc.WebViewPage">
      <namespaces>
        <add namespace="System.Web.Mvc" />
        <add namespace="System.Web.Mvc.Ajax" />
        <add namespace="System.Web.Mvc.Html" />
        <add namespace="System.Web.Routing" />
      </namespaces>
    </pages>
  </system.web.webPages.razor>

  <appSettings>
    <add key="webpages:Enabled" value="false" />
  </appSettings>

  <system.web>
        <httpHandlers>
      <add path="*" verb="*" type="System.Web.HttpNotFoundHandler"/>
    </httpHandlers>

    <pages
        validateRequest="false"
        pageParserFilterType="System.Web.Mvc.ViewTypeParserFilter, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"
        pageBaseType="System.Web.Mvc.ViewPage, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"
        userControlBaseType="System.Web.Mvc.ViewUserControl, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">
      <controls>
        <add assembly="System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" namespace="System.Web.Mvc" tagPrefix="mvc" />
      </controls>
    </pages>
  </system.web>

  <system.webServer>
    <validation validateIntegratedModeConfiguration="false" />

    <handlers>
      <remove name="BlockViewHandler"/>
      <add name="BlockViewHandler" path="*" verb="*" preCondition="integratedMode" type="System.Web.HttpNotFoundHandler" />
    </handlers>
  </system.webServer>
</configuration>
Run Code Online (Sandbox Code Playgroud)

这是Error.cshtml:

@model System.Web.Mvc.HandleErrorInfo

@{
    ViewBag.Title = "Error";
}

<h2>
    Sorry, an error occurred while processing your request.
</h2>
Run Code Online (Sandbox Code Playgroud)

什么可能导致此异常,为什么我不能在本地重现它?

vip*_*naz 203

首先,在web.config中设置customErrors ="Off"并重新部署以获取更详细的错误消息,以帮助我们诊断问题.您还可以RDP进入实例并从IIS本地浏览到该站点以查看错误.

<system.web>
      <customErrors mode="Off" />
Run Code Online (Sandbox Code Playgroud)

首先猜测 - 您有一些未设置为Copy Local = true的引用(很可能是Azure SDK引用).因此,所有依赖项都没有部署.

首先获取详细错误并更新您的问题.

更新:VS2013中现在提供的第二个选项是远程调试云服务或虚拟机.

  • 将customErrors设置为"off"最终显示出一些真正的异常.我现在在调查他们. (10认同)

Sha*_*rpC 7

我没有使用Azure,但我在本地遇到了同样的错误.使用<customErrors mode="Off" />似乎没有任何效果,但在事件查看器中检查应用程序日志会显示ASP.NET的警告,其中包含解决该问题所需的所有详细信息.


小智 6

如果您将此添加到您的 web.config 转换文件,您还可以设置某些发布选项以启用或禁用调试:

<system.web>
    <customErrors mode="Off" defaultRedirect="~/Error.aspx" xdt:Transform="Replace"/>
</system.web>
Run Code Online (Sandbox Code Playgroud)