在MVC4中使用API控制器,当控制器动作引发异常时,ELMAH不会记录错误.
我认为问题是MVC4将HTTP状态代码设置为500,并返回JSON对象中的异常详细信息,但不会抛出未处理的异常,所以ELMAH从不会看到它.
如何让ELMAH捕获状态码不是200的所有响应?
解决方法
前面描述的anwser不起作用我试过我的测试服务器并收到一个错误(“给定的过滤器实例必须实现一个或多个以下过滤器接口:IAuthorizationFilter,IActionFilter,IResultFilter,IExceptionFilter”)
然后我意识到发生了什么….您正在尝试将自定义过滤器添加到MVC全局过滤器(filters.Add(new ElmahHandledErrorLoggerFilter());)
要解决这个问题,我已经将过滤器注册分成了GlobalFilter和HttpFilter
FilterConfig.cs
public static void RegisterGlobalFilters(GlobalFilterCollection filters) { filters.Add(new HandleErrorAttribute()); } public static void RegisterHttpFilters(HttpFilterCollection filters) { filters.Add(new ElmahHandledErrorLoggerFilter()); }
Global.asax中
FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); FilterConfig.RegisterHttpFilters(GlobalConfiguration.Configuration.Filters);