1. ホーム
  2. asp.net-mvc

[解決済み] "リクエストの処理中に例外が発生しました。さらに、カスタムエラーページの実行中に別の例外が発生しました..."

2022-09-24 20:08:33

質問

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>

何がこの例外を引き起こすのでしょうか、そしてなぜローカルで再現できないのでしょうか?

どのように解決するのですか?

まず、web.config で customErrors = "Off" を設定し、再デプロイすると、問題の診断に役立つより詳細なエラー メッセージが表示されるようになります。 また、インスタンスに RDP して、ローカルに IIS からサイトをブラウズして、エラーを表示することもできます。

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

最初の推測では、いくつかの参照(おそらくAzure SDKの参照)が、Copy Local = trueに設定されていないことがあります。 そのため、すべての依存関係がデプロイされないのです。

最初に詳細なエラーを取得し、質問を更新してください。

UPDATE: VS2013 で利用可能になった 2 つ目のオプションは次のとおりです。 クラウド サービスまたは仮想マシンのリモート デバッグ .