源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

.NET 日志系统设计思路及实现代码

  • 时间:2020-01-23 02:52 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:.NET 日志系统设计思路及实现代码
日志很明显是帮助大家定位到问题的一个很重要的手段,本来是想直接使用的NLog 来做系统的日志工具,哎伤不起,一变态非要说这个有很多不可控制的因素,这里我给大家讲一下我是怎么实现日志模块的,欢迎拍砖 总体架构图 [img]http://files.jb51.net/file_images/article/201312/20131221151235787.jpg[/img] •    在这里我把日子的等级分为 跟踪,BUG 和错误 3种  定义枚举如下
[u]复制代码[/u] 代码如下:
/// <summary>     /// 日志等级     /// </summary>     public enum Loglevel     {         Track=1,         Bug,         Error     }
•    这里考虑日志的模块的可扩展性 (这里支持 数据库 和文件 2种方式)  这里使用适配器模式来完成本模块。 这里给大家来年终福利。贴点代码 定义一个接口ILogTarget
[u]复制代码[/u] 代码如下:
public interface ILogTarget     {         /// <summary>         /// 写入追踪信息         /// </summary>         /// <param name="LogContent"></param>         void WriteTrack(string LogContent);         /// <summary>         /// 写入BUG信息         /// </summary>         /// <param name="LogContent"></param>         void WriteBug(string LogContent);         /// <summary>         /// 写入错误信息         /// </summary>         /// <param name="LogContent"></param>         void WriteError(string LogContent);     }
•     FileLog ,和DBLog 2个类实现上面的接口 这里不贴上具体的现实
[u]复制代码[/u] 代码如下:
/// <summary>     /// 文件日志实现类     /// </summary>     public class FileLog : ILogTarget     {         public void WriteTrack(string LogContent)         {             throw new NotImplementedException();         }         public void WriteBug(string LogContent)         {             throw new NotImplementedException();         }         public void WriteError(string LogContent)         {             throw new NotImplementedException();         }     }
[u]复制代码[/u] 代码如下:
public class DBLog : ILogTarget     {         public void WriteTrack(string LogContent)         {             throw new NotImplementedException();         }         public void WriteBug(string LogContent)         {             throw new NotImplementedException();         }         public void WriteError(string LogContent)         {             throw new NotImplementedException();         }     }
[u]复制代码[/u] 代码如下:
public class SmartLog     {         private ILogTarget _adaptee;         public SmartLog(ILogTarget tragent)         {             this._adaptee = tragent;         }         public void WriteTrack(string LogContent)         {             _adaptee.WriteTrack(LogContent);         }         public void WriteBug(string LogContent)         {             _adaptee.WriteBug(LogContent);         }         public void WriteError(string LogContent)         {             _adaptee.WriteError(LogContent);         }     }
•   调用方式
[u]复制代码[/u] 代码如下:
SmartLog log =new SmartLog (new FileLog()); log.WriteTrack("Hello word");
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部