星空网 > 软件开发 > ASP.net

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();    }

运行可以看到效果:

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

 

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

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

东莞货运到泰国:https://www.goluckyvip.com/tag/88805.html
泰家物流:https://www.goluckyvip.com/tag/88806.html
快递可以寄泰国:https://www.goluckyvip.com/tag/88808.html
曼谷海运专线:https://www.goluckyvip.com/tag/88809.html
东莞至泰国货运:https://www.goluckyvip.com/tag/88810.html
从浙江邮寄到泰国:https://www.goluckyvip.com/tag/88811.html
七月份适合去日本旅游吗 7月份去日本哪里好玩:https://www.vstour.cn/a/363192.html
凤岗汽车站到松山湖风景区 松岗汽车站到凤凰山怎么坐车:https://www.vstour.cn/a/363193.html
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流