c#-Elmah不过滤/感知Web API上的错误
作者:互联网
我有一个配置了Elmah并可以正常工作的Web Api应用程序,日志正常创建.
为了从日志中隐藏/删除敏感数据,我尝试了this,但不适用于Web Api控制器.仅当MVC管道中发生错误(项目中有MVC和Web API控制器)时,才单击过滤器.
我也检查了this问题,但我的配置文件似乎还可以:
<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>
[...]
<location path="." inheritInChildApplications="false">
<system.web>
<httpModules>
<add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
<add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />
<add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />
</httpModules>
[..]
</system.web>
</location>
[...]
<system.webServer>
<modules runAllManagedModulesForAllRequests="true">
<add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" preCondition="managedHandler" />
<add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" preCondition="managedHandler" />
<add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" preCondition="managedHandler" />
</modules>
</system.webServer>
Global.asax中的过滤器:
public void ErrorLog_Filtering(object sender, ExceptionFilterEventArgs e)
{
var ctx = e.Context as HttpContext;
if (ctx == null) return;
ElmahDataFilter.Apply(e, ctx);
}
作为附加信息,如果我评论system.web> httpModules部分,则仍在正常创建日志.
解决方法:
ELMAH不会立即记录由ASP.NET Web API生成的错误.您还需要安装Elmah.Contrib.WebApi软件包:
Install-Package Elmah.Contrib.WebApi
然后在WebApiConfig.cs中配置Web API以将ELMAH用作异常记录器:
config.Services.Add(typeof(IExceptionLogger), new ElmahExceptionLogger());
有关更多信息,请查看我编写的指南Logging to ELMAH from Web API.在本教程中,您可能需要使用ELMAH替换elmah.io软件包,因为您可能正在使用其他错误记录器之一.
我刚刚确认安装这些软件包实际上会触发您添加到问题中的ErrorLog_Filtering代码.
标签:asp-net-web-api,elmah,c 来源: https://codeday.me/bug/20191026/1939063.html