zoukankan      html  css  js  c++  java
  • ABP源码分析八:Logger集成

    ABP使用Castle日志记录工具,并且可以使用不同的日志类库,比如:Log4Net, NLog, Serilog... 等等。对于所有的日志类库,Castle提供了一个通用的接口来实现,我们可以很方便的处理各种特殊的日志库,而且当业务需要的时候,很容易替换日志组件。

    Logger功能模块涉及到的接口和类不多,相对容易理解。

     

    LogSeverity 枚举类型,定义了5个日志级别:Info,Debug,Warn,Error, Fatal.

     

    IHasLogSeverity:封装了LogSeverity。UserFriendlyException,AbpValidationException实现了这个接口。Loghelper在对exeption做log的时候可以方便的通过实现了IHasLogSeverity的exeption的实例获取到logSeverity。然后根据logSeverity的级别log.

     

    Loghelper: 静态类。调用logger实例(实现CastleIlogger接口)完成log操作

     

    LoggerExtensions: 扩展了CastleIlogger接口的方法,封装更便捷的方法供Loghelper调用。

     

     

    在具体的web项目的application_start方法中注入logger实例。以下是注入log4net代码

     

    返回ABP源码分析系列文章目录

  • 相关阅读:
    4.函数
    3.文件操作及编码解码补充
    2.列表字符串字典元组集合
    1.杂项三元运算及字符编码
    python-数据类型补充及文件处理操作
    python-day02数据类型-字符串和列表的操作
    python-day01
    DOM
    javascript基本
    CSS几个属性
  • 原文地址:https://www.cnblogs.com/1zhk/p/5294466.html
Copyright © 2011-2022 走看看