分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 前端开发

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

发布时间:2023-09-06 01:54责任编辑:傅花花关键词:.NETMVC错误日志

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文件夹下就多了一个记录错误日志的文件了。

 转自:https://www.cnblogs.com/wei325/p/5433288.html

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

原文地址:https://www.cnblogs.com/yunspider/p/9043267.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved