.Net Mvc过滤器观察者模式记录网站报错信息 淩亂°似流年 2023-06-02 10:56 11阅读 0赞 ### 基本介绍: ### 观察者模式是一种对象行为模式。它定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新。在观察者模式中,主题是通知的发布者,它发出通知时并不需要知道谁是它的观察者,可以有任意数目的观察者订阅并接收通知。观察者模式不仅被广泛应用于软件界面元素之间的交互,在业务对象之间的交互、权限管理等方面也有广泛的应用。 # 第一步:自定义过滤器错误类(MyExceptionFilterAttribute.cs) # 1 using Sam.OA.Common; 2 using System.Web.Mvc; 3 4 namespace Sam.OA.WEBAPP.Models 5 { 6 public class MyExceptionFilterAttribute: HandleErrorAttribute 7 { 8 public override void OnException(ExceptionContext filterContext) 9 { 10 base.OnException(filterContext); 11 LogHelper.WriteLog(filterContext.Exception.ToString()); 12 } 13 } 14 } # 第二步:改造RegisterGlobalFilters.cs # 1 using Sam.OA.WEBAPP.Models; 2 using System.Web.Mvc; 3 4 namespace Sam.OA.WEBAPP 5 { 6 public class FilterConfig 7 { 8 public static void RegisterGlobalFilters(GlobalFilterCollection filters) 9 { 10 //filters.Add(new HandleErrorAttribute()); 11 filters.Add(new MyExceptionFilterAttribute()); //添加自定义错误类 12 } 13 } 14 } # 第三步:观察者模式实现操作日志 # **日志接口(ILogWrite.cs)** 1 namespace Sam.OA.Common 2 { 3 /// <summary> 4 /// 日志文件接口 5 /// </summary> 6 public interface ILogWrite 7 { 8 void WriteLogInfo(string txt); 9 } 10 } **记录文件中(TextFileWriter.cs)** 1 namespace Sam.OA.Common 2 { 3 public class TextFileWriter : ILogWrite 4 { 5 /// <summary> 6 /// 将错误信息记录到文件中 7 /// </summary> 8 /// <param name="txt"></param> 9 public void WriteLogInfo(string txt) 10 { 11 //具体实现方法略。。。。 12 } 13 } 14 } **记录SqlServer中(SqlServerWriter.cs)** 1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 7 namespace Sam.OA.Common 8 { 9 public class SqlServerWriter : ILogWrite 10 { 11 /// <summary> 12 /// 记录SqlServer数据库中 13 /// </summary> 14 /// <param name="txt"></param> 15 public void WriteLogInfo(string txt) 16 { 17 //具体实现方式略。。。。 18 } 19 } 20 } **日志文件帮助类(LogHelper.cs)** 1 using System; 2 using System.Collections.Generic; 3 using System.Threading; 4 5 namespace Sam.OA.Common 6 { 7 public class LogHelper 8 { 9 public static Queue<string> ExceptionStringQueue = new Queue<string>(); 10 public static List<ILogWrite> LogWriteList = new List<ILogWrite>(); 11 static LogHelper() 12 { 13 LogWriteList.Add(new TextFileWriter()); 14 LogWriteList.Add(new SqlServerWriter()); 15 ThreadPool.QueueUserWorkItem(obj => 16 { 17 while (true) 18 { 19 lock (ExceptionStringQueue) 20 { 21 if (ExceptionStringQueue.Count > 0) 22 { 23 string str = ExceptionStringQueue.Dequeue(); 24 foreach (var logWrite in LogWriteList) 25 { 26 logWrite.WriteLogInfo(str); 27 } 28 } 29 else 30 { 31 Thread.Sleep(30); 32 } 33 } 34 } 35 }); 36 } 37 public static void WriteLog(string exceptionText) 38 { 39 try 40 { 41 lock (ExceptionStringQueue) 42 { 43 ExceptionStringQueue.Enqueue(exceptionText); 44 } 45 } 46 catch (Exception ex) 47 { 48 throw ex; 49 } 50 } 51 } 52 } 转载于:https://www.cnblogs.com/chenyanbin/p/11373817.html
相关 .Net Mvc过滤器观察者模式记录网站报错信息 基本介绍: 观察者模式是一种对象行为模式。它定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新。在观察者模式中,主 淩亂°似流年/ 2023年06月02日 10:56/ 0 赞/ 12 阅读
相关 观察者模式 观察者模式 Observer 观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。 这个主题对象在状态上发生变化时,会通知所有观察者对 梦里梦外;/ 2022年08月03日 08:20/ 0 赞/ 94 阅读
相关 观察者模式 js观察者模式 <!DOCTYPE> <html> <head> <title> New Document </title> 刺骨的言语ヽ痛彻心扉/ 2022年07月21日 00:24/ 0 赞/ 88 阅读
相关 观察者模式 什么是观察者模式 有人这么说 > 观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。 > > 这个主题对象在状态上发生变化时,会通知所有观 梦里梦外;/ 2022年07月20日 12:05/ 0 赞/ 347 阅读
相关 观察者模式 场景描述: 一个气象站应用,可以实时获取温度、湿度和气压信息,气象站提供一个封装好的类WeatherData,该类有最新的气象信息,当这些信息发生变动的时候,类中的meas 叁歲伎倆/ 2022年06月14日 10:24/ 0 赞/ 239 阅读
相关 观察者模式 观察者模式:定义了对象之间的一对多的依赖,这样一来,当一个对象改变状态时,它的所有依赖者都会收到通知并自动更新。 观察者模式图: ![输入图片说明][13105107_Mf 旧城等待,/ 2022年06月03日 02:41/ 0 赞/ 339 阅读
相关 观察者模式 什么是观察者模式? 简单的来说,观察者模式=出版者+订阅者。用比较书面的话来说的话是:定义了对象之间的一对多依赖,当一所对应的对象状态改变时,它的所有依赖者都会收到通知并 你的名字/ 2022年02月01日 13:53/ 0 赞/ 465 阅读
相关 观察者模式 当对象间存在一对多关系时,则使用观察者模式(Observer Pattern)。比如,当一个对象被修改时,则会自动通知它的依赖对象。观察者模式属于行为型模式。 意图:定义对象 系统管理员/ 2021年09月17日 01:36/ 0 赞/ 564 阅读
相关 观察者模式 对象间存在一对多关系时,则使用观察者模式(Observer Pattern)。比如,当一个对象被修改时,则会自动通知它的依赖对象。观察者模式属于行为型模式。 介绍 ... 小灰灰/ 2020年06月13日 05:42/ 0 赞/ 650 阅读
还没有评论,来说两句吧...