我正在使用此问题的建议: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="Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\MyDB.mdf;Integrated Security=True;User Instance=True;MultipleActiveResultSets=True"" 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>
答案 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模块。