打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
ASP.NET MVC中错误日志信息记录

MVC中有一个处理异常的过滤器 HandleErrorAttribute

1.新建一个类继承自 HandleErrorAttribute,然后重写OnException这个方法

public class MyExceptionAttribute:HandleErrorAttribute    {        /// <summary>        /// 可捕获异常数据        /// </summary>        /// <param name="filterContext"></param>        public override void OnException(ExceptionContext filterContext)        {            base.OnException(filterContext);            Exception ex = filterContext.Exception;            //把错误信息写进队列        }    }

只要程序出错就会执行这个方法。

2.注册定义好的异常过虑器

打开App_Start文件夹中FilterConfig.cs修改

 public static void RegisterGlobalFilters(GlobalFilterCollection filters)        {            //filters.Add(new HandleErrorAttribute());            filters.Add(new MyExceptionAttribute());        }

 

验证一下:在1中定义的过虑器的ex行打一个断点,然后在控制器的action中增加一段出错的代码

 public ActionResult Index()        {            int a = Convert.ToInt16("aaa");            return Content(a.ToString());           // return View();        }

运行可以看到效果:

 

3.把错误信息存到队列中

因为直接把错误写到日志会出现多个人同时操作日志文件,会造成并发的问题,所以把错误存到队列,然后从队列中把数据记录到文件中不会造成并发,修改过虑器。

public class MyExceptionAttribute:HandleErrorAttribute    {        //创建一个队列        public static Queue<Exception> execptionQueue = new Queue<Exception>();        /// <summary>        /// 可捕获异常数据        /// </summary>        /// <param name="filterContext"></param>        public override void OnException(ExceptionContext filterContext)        {            base.OnException(filterContext);            Exception ex = filterContext.Exception;            //把错误信息写进队列            execptionQueue.Enqueue(ex);            //跳转到错误页            filterContext.HttpContext.Response.Redirect("/Error.html");        }    }

4.开启一个新的线程不断的读取队列,把消息写入日志文件

读取消息应该在程序开始的时候就开始执行,在Global.asax.cs中添加代码

 protected void Application_Start()        {            AreaRegistration.RegisterAllAreas();            WebApiConfig.Register(GlobalConfiguration.Configuration);            FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);            RouteConfig.RegisterRoutes(RouteTable.Routes);            BundleConfig.RegisterBundles(BundleTable.Bundles);            string filePath = Server.MapPath("/Log/");            ThreadPool.QueueUserWorkItem((a) => {                while (true)                {                    //判断一下队列中是否有数据                    if (MyExceptionAttribute.execptionQueue.Count > 0)                    {                        //出队                        Exception ex = MyExceptionAttribute.execptionQueue.Dequeue();                        if (ex != null)                        {                            //将异常信息写到日志文件中                            string fileName = DateTime.Now.ToString("yyyy-MM-dd");                            File.AppendAllText(filePath + fileName + ".txt", ex.ToString(), System.Text.Encoding.UTF8);                        }                        else                        {                            //如果队列中没有数据,休息5秒钟                            Thread.Sleep(5000);                        }                    }                    else                    {                        //如果队列中没有数据,休息                        Thread.Sleep(5000);                    }                }            });        }

完成,执行一条出错语句,Log文件夹下就多了一个记录错误日志的文件了。

 

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
基于AOP的MVC拦截异常让代码更优美
ASP.NET MVC 过滤器(五)
ASP.NET MVC 5 学习笔记:使用HandleErrorAttribute处理异常
Exception Handling in MVC
NoSQL初探之人人都爱Redis:(3)使用Redis作为消息队列服务场景应用案例
ASP.NET MVC5基础-过滤器(Filters)详解
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服