"Во время обработки вашего запроса произошло исключение. Кроме того, при выполнении пользовательской страницы ошибки произошло другое исключение..."

Я пытаюсь опубликовать веб-сайт MVC как веб-сайт Azure.

Когда я запускаю его локально, все работает нормально.

Но как только я опубликую его до 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>

Что может вызвать это исключение и почему я не могу его локально воспроизвести?

Ответ 1

Сначала установите customErrors = "Off" в файле web.config и повторно разверните его, чтобы получить более подробное сообщение об ошибке, которое поможет нам диагностировать проблему. Вы также можете включить RDP в экземпляр и перейти на сайт из IIS локально, чтобы просмотреть ошибки.

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

Сначала предположим, что у вас есть ссылки (скорее всего, ссылки на Azure SDK), которые не настроены на Копировать Local = true. Таким образом, все ваши зависимости не развертываются.

Сначала перейдите к подробной ошибке и обновите свой вопрос.

UPDATE: второй вариант, доступный в VS2013, - Удаленная отладка облачной службы или виртуальной машины.

Ответ 2

Я не использовал Azure, но я получил ту же ошибку локально. Использование <customErrors mode="Off" />, казалось, не имело никакого эффекта, но проверка журналов приложений в средстве просмотра событий выявила предупреждение ASP.NET, в котором были указаны все детали, необходимые для решения проблемы.

Ответ 3

Если вы добавите это в свой файл преобразования web.config, вы также можете установить определенные параметры публикации, чтобы включить или отключить отладку:

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

Ответ 4

Убедитесь, что вы очистили ошибки ModelState или продолжаете пытаться их обработать.

foreach (var modelValue in ModelState.Values)
               {
                   modelValue.Errors.Clear();
               }

Ответ 5

У меня была эта проблема только с redirectMode="ResponseRewrite" (redirectMode="ResponseRedirect" работала нормально), и ни одно из вышеупомянутых решений не помогло мне решить проблему. Однако после того, как я изменил пул приложений сервера "Управляемый режим конвейера" с "Классического" на "Интегрированный", пользовательская страница с ошибкой появилась, как и ожидалось.

Ответ 6

Вместо этого вы можете использовать Oracle.ManagedDataAccess.dll (скачать из Oracle), включить эту dll в папку bin проекта, добавить ссылку на эту dll в проект. В коде "с использованием Oracle.MangedDataAccess.Client". Разверните проект на сервере как обычно. Нет необходимости устанавливать Oracle Client на сервере. Нет необходимости добавлять информацию о сборке в web.config.