.NET 日志系统设计思路及实现代码
2013-12-21 00:00
761 查看
日志很明显是帮助大家定位到问题的一个很重要的手段,本来是想直接使用的NLog 来做系统的日志工具,哎伤不起,一变态非要说这个有很多不可控制的因素,这里我给大家讲一下我是怎么实现日志模块的,欢迎拍砖
总体架构图
• 在这里我把日子的等级分为 跟踪,BUG 和错误 3种 定义枚举如下
• 这里考虑日志的模块的可扩展性 (这里支持 数据库 和文件 2种方式) 这里使用适配器模式来完成本模块。 这里给大家来年终福利。贴点代码
定义一个接口ILogTarget
• FileLog ,和DBLog 2个类实现上面的接口 这里不贴上具体的现实
• 调用方式
总体架构图
• 在这里我把日子的等级分为 跟踪,BUG 和错误 3种 定义枚举如下
/// <summary> /// 日志等级 /// </summary> public enum Loglevel { Track=1, Bug, Error }
• 这里考虑日志的模块的可扩展性 (这里支持 数据库 和文件 2种方式) 这里使用适配器模式来完成本模块。 这里给大家来年终福利。贴点代码
定义一个接口ILogTarget
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个类实现上面的接口 这里不贴上具体的现实
/// <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(); } }
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(); } }
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); } }
• 调用方式
SmartLog log =new SmartLog (new FileLog()); log.WriteTrack("Hello word");
相关文章推荐
- .NET 日志系统设计思路及实现代码
- Linux下一个简单的日志系统的设计及其C代码实现
- Linux下一个简单的日志系统的设计及其C代码实现
- 系统操作日志设计-代码实现
- 系统操作日志设计-代码实现
- 系统操作日志设计-代码实现
- 系统操作日志设计-代码实现
- 系统操作日志设计-代码实现(转载)
- Linux下一个简单的日志系统的设计及其C代码实现
- 系统操作日志设计(二)-代码实现
- 系统操作日志设计(二)-代码实现
- Linux下一个简单的日志系统的设计及其C代码实现
- 实现基于组织机构的数据集权限系统的设计思路讲解
- (二)autoCode代码生成系统设计思路
- java web图书商城系统的需求分析及详细设计与代码实现
- 多年一直想完善的自由行政审批流程组件【2002年PHP,2008年.NET,2010年完善数据设计、代码实现】
- 转载:ASP.NET系统用户权限在.NET中的设计与实现
- ASP.NET系统用户权限在.NET中的设计与实现
- Winform开发框架之权限管理系统改进的经验总结(4)-一行代码实现表操作日志记录
- 实现基于组织机构的数据集权限系统的设计思路讲解【提供完整数据库设计下载】