“Ocorreu uma exceção ao processar o seu pedido. Além disso, outra exceção ocorreu durante a execução da página de erro personalizada ... ”

104

Estou tentando publicar um site MVC como um webrole do Azure.

Quando o executo localmente, tudo funciona bem.

Mas depois de publicá-lo no Azure e navegar para alguma ação MVC, recebo este erro:

Erro de Servidor na '/' Aplicação.

Erro de tempo de execução

Descrição: Ocorreu uma exceção ao processar sua solicitação. Além disso, outra exceção ocorreu ao executar a página de erro personalizada para a primeira exceção. A solicitação foi encerrada.

Não entendo como o gerenciador de erros pode encontrar uma exceção, porque os erros são tratados da maneira padrão:

public class FilterConfig
{
    public static void RegisterGlobalFilters(GlobalFilterCollection filters)
    {
        filters.Add(new HandleErrorAttribute());
    }
}

Este é meu 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>

Este é Error.cshtml:

@model System.Web.Mvc.HandleErrorInfo

@{
    ViewBag.Title = "Error";
}

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

O que pode causar essa exceção e por que não posso reproduzi-la localmente?

Ilya Kogan
fonte
41
Cara, seus erros geram erros. Isso é sério :)
Jack
Eu sugiro que você habilite o registro de erros detalhado no Portal de Gerenciamento e analise os registros no site FTP.
Jakub Konecki
Existe algo em seu layout que pode ser o culpado?
drch
@drch Não, nada mudou no layout desde a última vez que funcionou.
Ilya Kogan

Respostas:

214

Primeiro, defina customErrors = "Off" no web.config e reimplante para obter uma mensagem de erro mais detalhada que nos ajudará a diagnosticar o problema. Você também pode fazer RDP na instância e navegar até o site do IIS localmente para visualizar os erros.

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

Mas primeiro adivinhe - você tem algumas referências (provavelmente referências do SDK do Azure) que não estão definidas como Copy Local = true. Portanto, todas as suas dependências não estão sendo implantadas.

Obtenha primeiro o erro detalhado e atualize sua pergunta.

ATUALIZAÇÃO: uma segunda opção agora disponível no VS2013 é a depuração remota de um serviço em nuvem ou máquina virtual .

Viperguynaz
fonte
12
Definir customErrors como "off" finalmente mostrou algumas exceções reais. Estou investigando agora.
Ilya Kogan
1
Como está resultando em um erro de IIS, você também pode personalizá-los como um substituto a la benfoster.io/blog/aspnet-mvc-custom-error-pages
drzaus
Meus customErrors estão "Desligados", mas continuo vendo a mensagem "Desculpe, ocorreu um erro ao processar sua solicitação." erro. Você poderia me ajudar aqui? @Ilya Kogan
GuiPab
1
+1 simplesmente porque definir customerror = off me permitiu ver que o erro foi causado porque eu usei uma solução de site como modelo para outro site e esqueci de limpar a pasta bin, ou seja, era um problema de duplicação.
Paul Zahra
7

Eu não estava usando o Azure, mas recebi o mesmo erro localmente. Usar <customErrors mode="Off" />parecia não surtir efeito, mas a verificação dos logs do aplicativo no Visualizador de eventos revelou um aviso do ASP.NET que continha todos os detalhes de que eu precisava para resolver o problema.

SharpC
fonte
3

Se você adicionar isso ao seu arquivo de transformação web.config, você também pode definir certas opções de publicação para ter a depuração ativada ou desativada:

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

Ao publicar no IIS, pelo Web Deploy, apenas verifiquei as opções de publicação de arquivo e executei. Agora funciona! Depois disso, as caixas de seleção não precisam ser marcadas. Não acho que isso possa ser uma solução para todos, mas é a única coisa que eu precisava fazer para resolver meu problema. Boa sorte.

ASPaiva
fonte
0

Tive este problema apenas com redirectMode="ResponseRewrite"( redirectMode="ResponseRedirect"funcionou bem) e nenhuma das soluções acima ajudou a resolver o problema. No entanto, depois que alterei o "Modo de pipeline gerenciado" do pool de aplicativos do servidor de "Clássico" para "Integrado", a página de erro personalizada apareceu conforme o esperado.

Mike Godin
fonte
-1

Em vez disso, você pode usar Oracle.ManagedDataAccess.dll (baixar do Oracle), incluir essa dll em seu diretório bin do projeto, adicionar referência a essa dll no projeto. No código, "using Oracle.MangedDataAccess.Client". Implante o projeto no servidor como de costume. Não há necessidade de instalar o Oracle Client no servidor. Não há necessidade de adicionar informações de montagem em web.config.

user3597243
fonte
2
Como a Oracle entrou nessa situação?
Aamol