• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    .NET 日志系统设计思路及实现代码

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

    总体架构图

    •    在这里我把日子的等级分为 跟踪,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 日志系统解析
    上一篇:asp.net图片上传实例
    下一篇:关于 尝试读取或写入受保护的内存。这通常指示其他内存已损坏。的解决方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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