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

Posted

技术标签:

【中文标题】“处理您的请求时发生异常。此外,执行自定义错误页面时发生另一个异常......”【英文标题】:"An exception occurred while processing your request. Additionally, another exception occurred while executing the custom error page..." 【发布时间】:2013-06-24 11:34:02 【问题描述】:

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

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

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

“/”应用程序中的服务器错误。

运行时错误

说明:处理您的请求时发生异常。 此外,在执行自定义时发生了另一个异常 第一个异常的错误页面。请求已终止。

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

public class FilterConfig

    public static void RegisterGlobalFilters(GlobalFilterCollection filters)
    
        filters.Add(new HandleErrorAttribute());
    

这是我的 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>

这是Error.cshtml:

@model System.Web.Mvc.HandleErrorInfo

@
    ViewBag.Title = "Error";


<h2>
    Sorry, an error occurred while processing your request.
</h2>

什么会导致这个异常,为什么我不能在本地重现它?

【问题讨论】:

伙计,你的错误会引发错误。那是一些严肃的事情:) 我建议您在管理门户中启用详细的错误日志记录并查看 FTP 站点上的日志。 你的布局中有什么可能是罪魁祸首吗? @drch 不,布局自上次运行以来没有任何变化。 【参考方案1】:

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

<system.web>
      <customErrors mode="Off" />

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

首先查看详细错误并更新您的问题。

更新:VS2013 现在提供的第二个选项是Remote Debugging a Cloud Service or Virtual Machine。

【讨论】:

将 customErrors 设置为“off”最终显示了一些真正的异常。我现在正在调查他们。 由于它会导致 IIS 错误,您也可以将它们自定义为备用benfoster.io/blog/aspnet-mvc-custom-error-pages 我的 customErrors 为“关闭”,但我继续看到“抱歉,处理您的请求时出错”。错误。你能帮帮我吗? @Ilya Kogan +1 仅仅因为设置 customerror = off 让我看到错误是因为我使用网站解决方案作为另一个网站的模板而忘记清除 bin 文件夹,即是重复问题。【参考方案2】:

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

【讨论】:

【参考方案3】:

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

<system.web>
    <customErrors mode="Off" defaultRedirect="~/Error.aspx" xdt:Transform="Replace"/>
</system.web>

【讨论】:

【参考方案4】:

我只在redirectMode="ResponseRewrite" 上遇到了这个问题(redirectMode="ResponseRedirect" 工作正常),以上解决方案都没有帮助我解决这个问题。但是,一旦我将服务器的应用程序池的“托管管道模式”从“经典”更改为“集成”,自定义错误页面就会按预期出现。

【讨论】:

【参考方案5】:

当通过 Web Deploy 发布到 IIS 时,我刚刚检查了 文件发布选项并执行了。现在它起作用了!在此部署之后,不需要检查复选框。我不认为这可以为每个人提供解决方案,但这是我解决问题所需要做的唯一事情。祝你好运。

【讨论】:

【参考方案6】:

您可以改用 Oracle.ManagedDataAccess.dll(从 Oracle 下载),将该 dll 包含在您的项目 bin 目录中,在项目中添加对该 dll 的引用。在代码中,“使用 Oracle.MangedDataAccess.Client”。像往常一样将项目部署到服务器。无需在服务器上安装 Oracle 客户端。无需在 web.config 中添加程序集信息。

【讨论】:

Oracle 是如何出现在这幅画中的?

以上是关于“处理您的请求时发生异常。此外,执行自定义错误页面时发生另一个异常......”的主要内容,如果未能解决你的问题,请参考以下文章