ASP.NET MVC中错误日志信息记录
2016-04-29 10:22
615 查看
MVC中有一个处理异常的过滤器 HandleErrorAttribute
只要程序出错就会执行这个方法。
验证一下:在1中定义的过虑器的ex行打一个断点,然后在控制器的action中增加一段出错的代码
运行可以看到效果:
完成,执行一条出错语句,Log文件夹下就多了一个记录错误日志的文件了。
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文件夹下就多了一个记录错误日志的文件了。
相关文章推荐
- ASP.NET MVC异步处理请求的意义
- 在ASP.NET 2.0中操作数据之五:声明参数
- ASP.NET MVC SSO单点登录设计与实现
- 在ASP.NET 2.0中操作数据之四:使用ObjectDataSource展现数据
- 关于Web api授权的问题
- 在ASP.NET 2.0中操作数据之三:创建母版页和站点导航
- Asp.net 面向接口可扩展框架之类型转化基础服务
- 使用AspectJ提供的注解方式实现aop
- 深入分析HaspMap源码
- Form中runat="server"属性的意义
- 在ASP.NET 2.0中操作数据:创建母版页和站点导航
- 在ASP.NET 2.0中操作数据:使用ObjectDataSource展现数据
- 在ASP.NET 2.0中操作数据:声明参数
- ASP.NET集成模式下的管道事件
- Raspberry Pi3 ~ Eclipse中添加wiringPi 库函数
- Asp.net 图片的两种处理方式
- ASP.NET显示农历时间
- C#、Asp.Net 农历与阴历之间相互转化工具类
- 在ASP.NET 2.0中操作数据之二:创建一个业务逻辑层
- 使用ASP.NET创建线程实例教程