MyException - 我的异常网
当前位置:我的异常网» ASP » ASP.NET MVC 一致日志处理 让你的应用不再出现小黄页

ASP.NET MVC 一致日志处理 让你的应用不再出现小黄页

www.MyException.Cn  网友分享于:2013-08-22  浏览:0次
ASP.NET MVC 统一日志处理 让你的应用不再出现小黄页!

引言


异常处理是每一个系统都必要有的功能,在程序出错的时候不会给用户显示莫名其妙的页面,或暴露你的代码的堆栈信息!那么在ASP.NET MVC 如何正确处理异常并记录呢? 

答案是可以利用ASP.NET MVC Filter(筛选器)利用AOP的方式 进行全局异常捕获 自定义ExceptionFilter 

 

正文


 

 

废话不多说直接上源码

 在ASP.NET MVC 根目录新建个文件夹 命名为 Filter

 

 

在Filter新建一个Class类 命名为CustomExceptionAttribute,并让它继承FilterAttribute类和IExceptionFilter接口

如下

 

 

下面是代码

 代码思想为   

 

 

 

 

/// <summary>
    /// 系统集中异常处理
    /// 重写官方默认的HandleErrorAttribute处理
    /// </summary>
    public class CustomExceptionAttribute : FilterAttribute, IExceptionFilter
    {

        public void OnException(ExceptionContext filterContext)
        {
            //查看是否已处理异常 
            if (filterContext.ExceptionHandled == true)
            {
                //已处理 直接跳过
                return;
            }
            else
            {
                //记录日志
                var log = new ExceptionLogModel();
                log.ControllerName = (string)filterContext.RouteData.Values["controller"];//控制器名称
                log.ActionName = (string)filterContext.RouteData.Values["action"];       //操作名称
                log.LoginUser = "临时测试用户";                                            //异常操作的用户
                log.Url = filterContext.RequestContext.HttpContext.Request.Url.LocalPath; //异常发生的url
                log.LogLevel = LogLevel.Error;                                            //异常类型
                log.Source = filterContext.Exception.Source;                              //引发异常的对象
                log.ErrorMsg = filterContext.Exception.Message;                           //异常详情信息
                log.StackTrace = filterContext.Exception.StackTrace;                       //异常堆栈信息
                log.ExceptionLog();
            }

            //查看是否通过异步请求
            bool AjaxReq = filterContext.HttpContext.Request.IsAjaxRequest();
             
            //根据http状态码 跳转到指定的异常页面
            var httpException = new HttpException(null, filterContext.Exception);
            switch (httpException.GetHttpCode())
            {
                case 400:
                    if (!AjaxReq)
                    {
                        ViewResult result = new ViewResult
                        {
                            ViewName = "Page_400", //错误页
                            MasterName = null,     //指定母版页
                            ViewData = null,       //指定模型
                            TempData = filterContext.Controller.TempData
                        };

                        filterContext.Result = result;
                        filterContext.HttpContext.Response.Clear();
                        filterContext.HttpContext.Response.StatusCode = 400;
                    }
                    else
                    {
                        filterContext.Result = new HttpStatusCodeResult(System.Net.HttpStatusCode.BadRequest, filterContext.Exception.Message);
                    }
                    break;

                case 401:
                    if (!AjaxReq)
                    {
                        ViewResult result = new ViewResult
                        {
                            ViewName = "Page_401", //错误页
                            MasterName = null,     //指定母版页
                            ViewData = null,       //指定模型
                            TempData = filterContext.Controller.TempData
                        };

                        filterContext.Result = result;
                        filterContext.HttpContext.Response.Clear();
                        filterContext.HttpContext.Response.StatusCode = 401;
                    }
                    else
                    {
                        filterContext.Result = new HttpStatusCodeResult(System.Net.HttpStatusCode.Unauthorized, "You Must login to perform this operation");
                    }
                    break;

                case 403:
                    if (!AjaxReq)
                    {
                        ViewResult result = new ViewResult
                        {
                            ViewName = "Page_403", //错误页
                            MasterName = null,     //指定母版页
                            ViewData = null,       //指定模型
                            TempData = filterContext.Controller.TempData
                        };

                        filterContext.Result = result;
                        filterContext.HttpContext.Response.Clear();
                        filterContext.HttpContext.Response.StatusCode = 403;
                    }
                    else
                    {
                        filterContext.Result = new HttpStatusCodeResult(System.Net.HttpStatusCode.Forbidden, "You do not have permission to access this operation");
                    }

                    break;

                case 404:
                    if (!AjaxReq)
                    {
                        ViewResult result = new ViewResult
                        {
                            ViewName = "Page_404", //错误页
                            MasterName = null,     //指定母版页
                            ViewData = null,       //指定模型
                            TempData = filterContext.Controller.TempData //临时数据
                        };

                        filterContext.Result = result;
                        filterContext.HttpContext.Response.Clear();
                        filterContext.HttpContext.Response.StatusCode = 404;
                    }
                    else
                    {
                        filterContext.Result = new HttpStatusCodeResult(System.Net.HttpStatusCode.NotFound, "The requested resource was not found");
                    }

                    break;

                case 500:
                    if (!AjaxReq)
                    {
                        ViewResult result = new ViewResult
                        {
                            ViewName = "Page_500", //错误页
                            MasterName = null,     //指定母版页
                            ViewData = null,       //指定模型
                            TempData = filterContext.Controller.TempData
                        };

                        filterContext.Result = result;
                        filterContext.HttpContext.Response.Clear();
                        filterContext.HttpContext.Response.StatusCode = 500;
                    }
                    else
                    {
                        filterContext.Result = new HttpStatusCodeResult(System.Net.HttpStatusCode.InternalServerError, filterContext.Exception.Message);
                    }

                    break;

                default:
                    if (!AjaxReq)
                    {
                        ViewResult result = new ViewResult
                        {
                            ViewName = "Page_500", //错误页
                            MasterName = null,     //指定母版页
                            ViewData = null,       //指定模型
                            TempData = filterContext.Controller.TempData
                        };

                        filterContext.Result = result;
                        filterContext.HttpContext.Response.Clear();
                        filterContext.HttpContext.Response.StatusCode = 500;
                    }
                    else
                    {
                        filterContext.Result = new HttpStatusCodeResult(System.Net.HttpStatusCode.InternalServerError, filterContext.Exception.Message);
                    }

                    break;

            }

            //设置异常已经处理,否则会被其他异常过滤器覆盖
            filterContext.ExceptionHandled = true;
            //在派生类中重写时,获取或设置一个值,该值指定是否禁用IIS自定义错误。
            filterContext.HttpContext.Response.TrySkipIisCustomErrors = true;
        }

 

 

最后在MVC项目根目录下 App_Start文件的FilterConfig.CS文件下 修改内容

 

 

 

 完毕 现在你控制器所有异常 都会被捕获

 

文章评论

十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
鲜为人知的编程真相
鲜为人知的编程真相
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
如何成为一名黑客
如何成为一名黑客
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
中美印日四国程序员比较
中美印日四国程序员比较
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
旅行,写作,编程
旅行,写作,编程
10个调试和排错的小建议
10个调试和排错的小建议
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
程序员都该阅读的书
程序员都该阅读的书
2013年美国开发者薪资调查报告
2013年美国开发者薪资调查报告
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
漫画:程序员的工作
漫画:程序员的工作
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
Java程序员必看电影
Java程序员必看电影
2013年中国软件开发者薪资调查报告
2013年中国软件开发者薪资调查报告
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
我是如何打败拖延症的
我是如何打败拖延症的
为什么程序员都是夜猫子
为什么程序员都是夜猫子
程序员应该关注的一些事儿
程序员应该关注的一些事儿
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
编程语言是女人
编程语言是女人
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
那些性感的让人尖叫的程序员
那些性感的让人尖叫的程序员
Google伦敦新总部 犹如星级庄园
Google伦敦新总部 犹如星级庄园
老程序员的下场
老程序员的下场
程序员的鄙视链
程序员的鄙视链
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
代码女神横空出世
代码女神横空出世
每天工作4小时的程序员
每天工作4小时的程序员
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
那些争议最大的编程观点
那些争议最大的编程观点
程序员和编码员之间的区别
程序员和编码员之间的区别
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
一个程序员的时间管理
一个程序员的时间管理
 程序员的样子
程序员的样子
总结2014中国互联网十大段子
总结2014中国互联网十大段子
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有