zoukankan      html  css  js  c++  java
  • 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文件夹下就多了一个记录错误日志的文件了。

  • 相关阅读:
    java第二周的学习知识
    java第一次课
    今天晚上有事,代码假期完成。
    [leetcode] Minimum Path Sum
    java访问权限整理
    java IO整理-File
    java初始化顺序
    enum使用整理
    工厂模式总结
    java IO-流
  • 原文地址:https://www.cnblogs.com/wei325/p/5433288.html
Copyright © 2011-2022 走看看