ELMAH没有记录MVC 2应用程序中的错误

时间:2011-02-03 03:34:44

标签: c# asp.net asp.net-mvc elmah

我正在使用此问题的建议:How to get ELMAH to work with ASP.NET MVC [HandleError] attribute?

我使用了Aziz的第二个代码示例。

我运行调试器以查看发生错误时会发生什么。 HandleErrorAttribute类中的主要功能是:

public override void OnException(ExceptionContext context)
{
    base.OnException(context);

    var e = context.Exception;
    if (!context.ExceptionHandled   // if unhandled, will be logged anyhow
        || RaiseErrorSignal(e)      // prefer signaling, if possible
        || IsFiltered(context))     // filtered?
        return;

    LogException(e);
}

它到达if语句。 context.ExceptionHandled返回true,RaiseErrorSignal(e)也返回true。永远不会达到IsFiltered,它只会返回,永远不会达到LogException(e)

有没有人碰到这个?

编辑:添加web.config

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <configSections>
    <sectionGroup name="elmah">
      <section name="security" requirePermission="false" type="Elmah.SecuritySectionHandler, Elmah" />
      <section name="errorLog" requirePermission="false" type="Elmah.ErrorLogSectionHandler, Elmah" />
      <section name="errorMail" requirePermission="false" type="Elmah.ErrorMailSectionHandler, Elmah" />
      <section name="errorFilter" requirePermission="false" type="Elmah.ErrorFilterSectionHandler, Elmah" />
    </sectionGroup>
  </configSections>
  <elmah>
    <security allowRemoteAccess="0" />
    <errorLog type="Elmah.SqlErrorLog, Elmah" connectionStringName="AppDb" />
  </elmah>
  <appSettings></appSettings>
  <connectionStrings>
    <add name="AppDb" connectionString="metadata=res://*/Models.MyDB.csdl|res://*/Models.MyDB.ssdl|res://*/Models.MyDB.msl;provider=System.Data.SqlClient;provider connection string=&quot;Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\MyDB.mdf;Integrated Security=True;User Instance=True;MultipleActiveResultSets=True&quot;" providerName="System.Data.EntityClient" />
  </connectionStrings>
  <system.web>
    <compilation debug="true" targetFramework="4.0">
      <assemblies>
        <add assembly="System.Web.Abstractions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
        <add assembly="System.Web.Routing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
        <add assembly="System.Web.Mvc, Version=2.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
        <add assembly="System.Data.Entity, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
      </assemblies>
    </compilation>
    <authentication mode="Forms">
      <forms loginUrl="~/Account/LogOn" timeout="2880" />
    </authentication>        
    <pages>
      <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>
    <httpHandlers>
      <add verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah" />
    </httpHandlers>
    <httpModules>
      <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
      <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />
      <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />
    </httpModules>
    <customErrors mode="On" defaultRedirect="Error.aspx">
      <error statusCode="403" redirect="NoAccess.htm" />
      <error statusCode="404" redirect="FileNotFound.htm" />
    </customErrors>
  </system.web>
  <system.webServer>
    <validation validateIntegratedModeConfiguration="false" />
    <modules runAllManagedModulesForAllRequests="true">
      <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
      <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />
      <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />
    </modules>
    <handlers>
      <add name="Elmah" verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah" />
    </handlers>
  </system.webServer>
  <runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
      <dependentAssembly>
        <assemblyIdentity name="System.Web.Mvc" publicKeyToken="31bf3856ad364e35" />
        <bindingRedirect oldVersion="1.0.0.0" newVersion="2.0.0.0" />
      </dependentAssembly>
    </assemblyBinding>
  </runtime>
</configuration>

3 个答案:

答案 0 :(得分:2)

您的AppDb连接字符串看起来像是一个Entity Framework连接字符串。我不认为ELMAH是为了识别这种格式而编写的。尝试给ELMAH一个标准的SQL连接字符串,看看它是否有效。

答案 1 :(得分:0)

它的短循环逻辑因此它将停在|| RaiseErrorSignal(e)而不是评估IsFiltered(context)

context.ExceptionHandled为true的事实表明您已经在try代码块中自己明确地处理了异常。在这种情况下,您需要明确告诉ELMAH处理错误:

catch (Exception ex)
{
    // do something 
    // etc

    // now tell ELMAH to handle it too
    ErrorSignal.FromCurrentContext().Raise(ex);
}

答案 2 :(得分:0)

RaiseErrorSignal(e)的调用将在ELMAH中记录错误,如果LogException(e)返回true,则不需要调用RaiseErrorSignal(e)

如果正确配置了ELMAH,则RaiseErrorSignal(e)LogException(e)都会导致记录错误。 RaiseErrorSignal(e)可能返回false的原因有几个,因此LogException(e)仅作为备份应该发出信号失败。

如果ELMAH中仍未显示错误,那么您的配置可能会出现问题。您能否发布Web.config的相关部分,以便我们看看?即,请在<elmah /><system.web />中发布<system.webServer />部分以及您的http模块(如果您使用的是IIS7环境)。

更新

正如Erik King所指出的那样 - 您的连接字符串'AppDb'适用于Entity Framework。它不能用作ErrorLog连接字符串。如果向Web.config添加标准连接字符串并将ErrorLog指向它,则ELMAH 开始正确记录。

如果您不知道 - 必须在应该过滤的任何模块之后声明ErrorFilter HttpModule。在当前的Web.config中,如果要定义过滤器,则只应用于ErrorLog模块而不是ErrorMail模块。