博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Orchard源码分析(4.2):Orchard.Logging.LoggingModule类
阅读量:5091 次
发布时间:2019-06-13

本文共 1502 字,大约阅读时间需要 5 分钟。

与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
Castle.Core.Logging.AbstractLoggerFactory
参考资料:

转载于:https://www.cnblogs.com/alby/archive/2012/10/18/orchard-LoggingModule.html

你可能感兴趣的文章
两种最常用的Sticky footer布局方式
查看>>
Scrapy实战篇(三)之爬取豆瓣电影短评
查看>>
HDU 5510 Bazinga KMP
查看>>
[13年迁移]Firefox下margin-top问题
查看>>
Zookeeper常用命令 (转)
查看>>
Enterprise Library - Data Access Application Block 6.0.1304
查看>>
重构代码 —— 函数即变量(Replace temp with Query)
查看>>
Bootstrap栅格学习
查看>>
程序员的数学
查看>>
聚合与组合
查看>>
如何理解汉诺塔
查看>>
洛谷 P2089 烤鸡【DFS递归/10重枚举】
查看>>
Linux基本操作
查看>>
osg ifc ifccolumn
查看>>
C++ STL partial_sort
查看>>
centos redis 安装过程,解决办法
查看>>
IOS小技巧整理
查看>>
WebDriverExtensionsByC#
查看>>
我眼中的技术地图
查看>>
lc 145. Binary Tree Postorder Traversal
查看>>