我尝试使用全局属性
编辑:更新了最终解决方案
public class HandleAndLogErrorAttribute : HandleErrorAttribute
{
private static readonly ILog log = Log<HandleAndLogErrorAttribute>.Create();
public override void OnException(ExceptionContext filterContext)
{
if (!filterContext.ExceptionHandled)
{
log.Error("Unhandled exception", filterContext.Exception);
if (filterContext.HttpContext.Request.IsAjaxRequest())
{
filterContext.Result = new { Message = filterContext.Exception.Message, StackTrace = filterContext.Exception.StackTrace }.AsJson();
filterContext.ExceptionHandled = true;
filterContext.HttpContext.Response.Clear();
filterContext.HttpContext.Response.StatusCode = 500;
filterContext.HttpContext.Response.TrySkipIisCustomErrors = true;
}
else
base.OnException(filterContext);
}
}
}
问题是 MVC 将忽略结果并呈现错误页面,如果我设置filterContext.ExceptionHandled = true;
它不会忽略结果,但它会返回代码 200 而不是 500,因此我在客户端上的通用错误处理程序不会检测到错误。我不能返回 200,因为这样我的调用成功方法会以意外行为触发。
有任何想法吗?