MVC Webサイトを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" />
ただし、最初の推測-Copy Local = trueに設定されていない参照(ほとんどの場合、Azure SDK参照)があります。したがって、すべての依存関係がデプロイされているわけではありません。
最初に詳細なエラーにアクセスして、質問を更新してください。
更新:VS2013で利用できる2番目のオプションは、 クラウドサービスまたは仮想マシンのリモートデバッグ です。
Azureを使用していませんでしたが、ローカルで同じエラーが発生しました。 <customErrors mode="Off" />
を使用しても効果がないように見えますが、イベントビューアーでアプリケーションログを確認すると、問題を解決するために必要なすべての詳細を含むASP.NETからの警告が明らかになりました。
これをweb.config変換ファイルに追加する場合、特定の公開オプションを設定してデバッグを有効または無効にすることもできます。
<system.web>
<customErrors mode="Off" defaultRedirect="~/Error.aspx" xdt:Transform="Replace"/>
</system.web>
この問題はredirectMode="ResponseRewrite"
(redirectMode="ResponseRedirect"
でうまくいきました)のみで発生し、上記の解決策のどれも問題の解決に役立ちませんでした。ただし、サーバーのアプリケーションプールの「管理されたパイプラインモード」を「クラシック」から「統合」に変更すると、カスタムエラーページが期待どおりに表示されました。