zoukankan      html  css  js  c++  java
  • asp.net mvc中配置全局异常过滤器

    第一步:定义一个类:SysHandlerErrorAttribute 继承HandleErrorAttribute

    重写OnException方法

    using Dw.Util;
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Mvc;
    
    namespace LoanH5_2020.Models
    {
        public class SysHandlerErrorAttribute : HandleErrorAttribute
        {
            public override void OnException(ExceptionContext filterContext)
            {
                //1.获取异常对象
                Exception ex = filterContext.Exception;
                //2.获取请求的类名和方法名
                string strController = filterContext.RouteData.Values["controller"].ToString();
                string strAction = filterContext.RouteData.Values["action"].ToString();
                //3.记录异常日志
                string errMsg = String.Format("控制器:{0};Action:{1};异常信息:{2};", strController, strAction, ex.ToString());
                NLogHelp.WriteInfo(errMsg);
                NLogHelp.WriteDebug(errMsg);
                //重定向到友好页面
                filterContext.Result = new RedirectResult("/Error/Index");
                //标记异常已经处理完毕
                filterContext.ExceptionHandled = true;
                base.OnException(filterContext);
            }
        }
    }

    第二步 在 filterConfig中添加自定义的SysHandlerErrorAttribute

    using LoanH5_2020.Models;
    using System.Web;
    using System.Web.Mvc;
    
    namespace LoanH5_2020
    {
        public class FilterConfig
        {
            public static void RegisterGlobalFilters(GlobalFilterCollection filters)
            {
                filters.Add(new HandleErrorAttribute());
                filters.Add(new SysHandlerErrorAttribute());
            }
        }
    }

    第三步,在Web.config中配置system.web节点下

     <customErrors mode="On"></customErrors>
  • 相关阅读:
    Linux 软件安装到哪里合适,目录详解
    python如何判断1个列表中所有的数据都是相等的?
    web接口开发基础知识-什么是web接口?
    MIME TYPE是什么?
    jenkins展示html测试报告(不使用html publisher)
    【转】Java虚拟机的JVM垃圾回收机制
    Map 排序
    sql in 和 exist的区别
    distinct和group by 去掉重复数据分析
    sql执行机制
  • 原文地址:https://www.cnblogs.com/yechangzhong-826217795/p/13932012.html
Copyright © 2011-2022 走看看