| 声明:本方式适用于MVC。本代码只适用于.NET Core MVC. 先创建一个类继承ExceptionFilterAttribute这个抽象类,并override它的方法OnException。 代码如下:  
     /// <summary>
    /// 处理错误信息
    /// </summary>
    public class ErrorHandleAttribute : ExceptionFilterAttribute
    {
        public override void OnException(ExceptionContext filterContext)
        {
            //获取异常信息,入库保存
            var exception = filterContext.Exception;
            var controllerName = filterContext.RouteData.Values["controller"].ToString();
            var actionName = filterContext.RouteData.Values["action"].ToString();
            var msg = $"出错位置:{controllerName}/{actionName}----出错时间:{DateTime.Now:yyyy-MM-dd HH:mm:ss:fff}";
            Log4NetHelp.Error(msg, exception);//记录异常日志到本地磁盘
            filterContext.Result = new RedirectResult("/Home/Error");
            EmailHelper.SendMail(exception);//发送邮件通知到相关人员
            base.OnException(filterContext);
        }
    } 如何使用呢? 只需要在需要捕捉异常的控制器加上[ErrorHandle]即可。 例如:  
     [ErrorHandle]
    public abstract class AdminControllerBase : Controller
    {
          //代码逻辑
    } 如果继承AdminControllerBase或者带有[ErrorHandle]特性的类和方法出现了错误,都会执行OnException方法,然后就可以记录异常日志和发送邮件通知到相关人员了。 |