Orchard源码分析(4.2):Orchard.Logging.LoggingModule类

与CollectionOrderModule一样,LoggingModule也是一个Autofac模块。它以属性注入的方式给需要日志服务的对象设置Logger。

   如果一个类有Orchard.Logging.ILogger型的公共可写实例属性(忽略索引),Autofac容器在解析(Resolve)该类的时 候,将"注入"一个ILogging实现类的实例。Orchard默认会注入一个CastleLogger对象。当然Orchard也允许一个类中有多个 ILogger型属性,也支持将CastleLogger替换成其他Logger。
如有必要,请先了解一下简单工厂模式、抽象工厂模式和适配器模式。CastleLoggerFactory工厂负责创建CastleLogger对象,而CastleLoggerFactory适配了OrchardLog4netFactory;CastleLogger实际上适配的是OrchardLog4netLogger;OrchardLog4netLogger又适配了log4net.Core.ILogger——也就是说CastleLogger是log4net.Core.ILogger经过层层包装的结果
 
如果有类TestContrller,其有一个名为Logger的ILogger型属性,注入流程如下: 1、Autofac容器创建TestController类的实例instance; 2、检查instance是否有一个ILogger型的公共可写实例属性。如果有(有可能还不只一个)则进入步骤3,否则以下步骤不没必要进行了; 3、从缓存中获取TestController类型对应的Logger,如果获取成功进入步骤6; 4、从Autofac容器获取ILogger:
从容器中获取CastleLoggerFactory
->CastleLoggerFactory创建ILogger对象
->交由OrchardLog4netFactory创建OrchardLog4netLogger
->交由log4net.LogManager.GetLogger创建一个log4net.Core.ILogger对象
->log4net.Core.ILogger对象适配成OrchardLog4netLogger对象
->OrchardLog4netLogger对象适配成CastleLogger对象
->CastleLoggerFactory最终返回一个CastleLogger对象
5、缓存CastleLogger对象(与TestController类关联)
6、将CastleLogger注入TestContrller对象的Logger属性。
 
 
 
相关类型:
Orchard.Logging.CastleLogger : Orchard.Logging.ILogger
Orchard.Logging.CastleLoggerFactory : Orchard.Logging.ILoggerFactorya
Orchard.Logging.OrchardLog4netFactory : Castle.Core.Logging.ILoggerFactory
Orchard.Logging.OrchardLog4netLogger

转载于:https://www.cnblogs.com/lhxsoft/p/5322501.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值