当前位置:  编程技术>.net/c#/asp.net

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

    来源: 互联网  发布时间:2014-08-25

    本文导语:  日志很明显是帮助大家定位到问题的一个很重要的手段,本来是想直接使用的NLog 来做系统的日志工具,哎伤不起,一变态非要说这个有很多不可控制的因素,这里我给大家讲一下我是怎么实现日志模块的,欢迎拍砖 总体架构...

日志很明显是帮助大家定位到问题的一个很重要的手段,本来是想直接使用的NLog 来做系统的日志工具,哎伤不起,一变态非要说这个有很多不可控制的因素,这里我给大家讲一下我是怎么实现日志模块的,欢迎拍砖

总体架构图

•    在这里我把日子的等级分为 跟踪,BUG 和错误 3种  定义枚举如下

代码如下:

///
    /// 日志等级
    ///
    public enum Loglevel
    {
        Track=1,
        Bug,
        Error
    }

•    这里考虑日志的模块的可扩展性 (这里支持 数据库 和文件 2种方式)  这里使用适配器模式来完成本模块。 这里给大家来年终福利。贴点代码
定义一个接口ILogTarget
代码如下:

public interface ILogTarget
    {
        ///
        /// 写入追踪信息
        ///
        ///
        void WriteTrack(string LogContent);

        ///
        /// 写入BUG信息
        ///
        ///
        void WriteBug(string LogContent);

        ///
        /// 写入错误信息
        ///
        ///
        void WriteError(string LogContent);

    }



•     FileLog ,和DBLog 2个类实现上面的接口 这里不贴上具体的现实
代码如下:

///
    /// 文件日志实现类
    ///
    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");


    
 
 

您可能感兴趣的文章:

  • php 模拟 asp.net webFrom 按钮提交事件的思路及代码
  • .net+mssql制作抽奖程序思路及源码
  • .NET单点登陆的实现方法及思路
  • NET c#索引器(indexer)介绍及代码示例
  • asp.net文字水印功能简单代码
  • C#/.NET字符串加密和解密实现(AES和RSA代码举例)
  • asp.net读取本地与全局资料文件的代码
  • c#/ASP.NET操作cookie(读写)代码示例
  • asp.net正则表达式提取中文的代码示例
  • .NET下 c#通过COM组件操作并导出Excel实例代码
  • asp.net使用mshtml处理html的代码
  • .net中string实现无重复数字的代码一例
  • asp.net 判断当前日期是该年中第几周的代码
  • 推荐免费源代码下载网站WWW.CPPN.NET
  • asp.net 获取目录中图片的代码
  • asp.net中利用正则表达式判断一个字符串是否为数字的代码
  • asp.net防止页面刷新重复提交的代码
  • C#.NET程序添加到右键菜单的实现代码
  • asp.net 获取ashx中数据的代码
  • asp.net 正则表达式匹配图片路径的实现代码
  • asp.net弹出消息框、确认框的代码汇总
  • asp.net文件分块下载的实现代码
  • asp.net简单的文件上传代码
  • vb.net实现后台发送短信的代码
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • asp.net 参数不同共用一个页面的实现方法
  • Asp.net防止重复提交的实现方法
  • ASP.NET MVC3 实现全站重定向的简单方法
  • javascript开源软件 iis7站长之家
  • 用linux做服务器运行ASP.net网站,请问具体怎样实现??
  • asp.net session实现用户登录的疑问
  • asp.net用Zxing库实现条形码输出的具体实现
  • asp.net 实现php的md5()函数功能
  • asp.net后台弹窗怎么实现
  • c#(asp.net)实现的文件下载函数
  • asp.net后台弹窗如何实现
  • .net压缩功能实现方法
  • asp.net datalist绑定数据后可以上移下移实现示例
  • Asp.net设置GridView自适应列宽的实现代码
  • .net实现文件读写的几种常用方法
  • .NET实现父窗体关闭而不影响子窗体的方法
  • 在.net中用CheckBoxList实现单选
  • .NET实现:EXE文件开机自动启动的方法
  • 如何让C#、VB.NET实现复杂的二进制操作
  • asp.net利用存储过程实现模糊查询示例分享
  • java命名空间javax.net类socketfactory的类成员方法: createsocket定义及介绍
  • .NET版的ExtJS库 Ext.Net
  • java命名空间java.net类datagramsocket的类成员方法: disconnect定义及介绍
  • node.js的.net扩展 node.net
  • java命名空间java.net类datagramsocket的类成员方法: close定义及介绍
  • 为什么输http://www.china-java.net,会自动改为http://www.china-java.net:8081?
  • java命名空间java.net接口cookiestore的类成员方法: get定义及介绍
  • 各位之不知道net-snmp是否收费?我的产品中用到了net-snmp lib是否需要向什么单位或者组织付费?
  • java命名空间java.net类socket的类成员方法: isbound定义及介绍
  • 【人才】有没有人会用VC6.0/VS2003.NET/VS2005.NET写WINDOWS下的驱动程序呀。
  • java命名空间java.net类datagrampacket的类成员方法: getsocketaddress定义及介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3