Orchard学习 01、orchard日志
一、日志模块类图


publicclassNullLogger:ILogger
{
privatestaticreadonlyILogger _instance =newNullLogger();
publicstaticILoggerInstance
{
get
{
return _instance;
}
}
#region ILogger 成员 public bool IsEnabled(LogLevel level)
{
returnfalse;
} publicvoidLog(LogLevel level,Exception exception,string format,paramsobject[] args)
{ } #endregion
}
publicclassLoggingModule:Module
{
privatereadonlyConcurrentDictionary<string,ILogger> _loggerCache; publicLoggingModule()
{
_loggerCache =newConcurrentDictionary<string,ILogger>();
} protectedoverridevoidLoad(ContainerBuilder moduleBuilder)
{
// by default, use Orchard's logger that delegates to Castle's logger factory
moduleBuilder.RegisterType<CastleLoggerFactory>().As<ILoggerFactory>().InstancePerLifetimeScope();
moduleBuilder.RegisterType<OrchardLog4netFactory>().As<Castle.Core.Logging.ILoggerFactory>().InstancePerLifetimeScope().WithParameter(newNamedParameter("isFullTrust",false)); // call CreateLogger in response to the request for an ILogger implementation
moduleBuilder.Register(CreateLogger).As<ILogger>().InstancePerDependency();
} protectedoverridevoidAttachToComponentRegistration(IComponentRegistry componentRegistry,IComponentRegistration registration)
{
var implementationType = registration.Activator.LimitType; // build an array of actions on this type to assign loggers to member properties
var injectors =BuildLoggerInjectors(implementationType).ToArray(); // if there are no logger properties, there's no reason to hook the activated event
if(!injectors.Any())
return; // otherwise, whan an instance of this component is activated, inject the loggers on the instance
registration.Activated+=(s, e)=>
{
foreach(var injector in injectors)
injector(e.Context, e.Instance);
};
} privateIEnumerable<Action<IComponentContext,object>>BuildLoggerInjectors(Type componentType)
{
// Look for settable properties of type "ILogger"
var loggerProperties = componentType
.GetProperties(BindingFlags.SetProperty|BindingFlags.Public|BindingFlags.Instance)
.Select(p =>new
{
PropertyInfo= p,
p.PropertyType,
IndexParameters= p.GetIndexParameters(),
Accessors= p.GetAccessors(false)
})
.Where(x => x.PropertyType==typeof(ILogger))// must be a logger
.Where(x => x.IndexParameters.Count()==)// must not be an indexer
.Where(x => x.Accessors.Length!=|| x.Accessors[].ReturnType==typeof(void));//must have get/set, or only set // Return an array of actions that resolve a logger and assign the property
foreach(var entry in loggerProperties)
{
var propertyInfo = entry.PropertyInfo;
yield return(ctx, instance)=>
{
string component = componentType.ToString();
if(component != instance.GetType().ToString())
{
return;
}
var logger = _loggerCache.GetOrAdd(component, key => ctx.Resolve<ILogger>(newTypedParameter(typeof(Type), componentType)));
propertyInfo.SetValue(instance, logger,null);
};
}
} privatestaticILoggerCreateLogger(IComponentContext context,IEnumerable<Parameter> parameters)
{
// return an ILogger in response to Resolve<ILogger>(componentTypeParameter)
var loggerFactory = context.Resolve<ILoggerFactory>();
var containingType = parameters.TypedAs<Type>();
return loggerFactory.CreateLogger(containingType);
}
}
<?xml version="1.0" encoding="utf-8"?>
<log4net>
<root> <priority value="ERROR"/>
<appender-refref="error-file"/>
</root> <logger name="NHibernate.Cache">
<priority value="ERROR"/>
</logger> <logger name="NHibernate.AdoNet.AbstractBatcher">
<priority value="ERROR"/>
</logger> <logger name="NHibernate.Util.ADOExceptionReporter">
<priority value="ERROR"/>
</logger> <appender name="error-file" type="Orchard.Logging.OrchardFileAppender">
<file value="orchard-error"/>
<appendToFile value="true"/>
<immediateFlush value="false"/>
<staticLogFileName value="false"/>
<rollingStyle value="Date"/>
<datepattern value="-yyyy.MM.dd'.log'"/>
<lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %logger - %P{Tenant} - %message%newline %P{Url}%newline"/>
</layout>
</appender>
</log4net>
/// <summary>
/// 要使用日志的类型
/// </summary>
publicclassThing
{
publicThing()
{
Logger=NullLogger.Instance;
}
/// <summary>
/// 设置类型为 ILogger 的属性
/// </summary>
publicILoggerLogger
{
get;
set;
}
publicvoidTestMethod()
{
//这使用Log方法则 Logger属性 会被设置为 CastleLogger类;使用Error方法 Logger属性 会被设置为OrchardLog4netLogger类
Logger.Log(Orchard.Logging.LogLevel.Error,newException("测试异常"),"测试异常使用CastleLogger类型");
Logger.Error(newException("测试异常"),"测试异常使用OrchardLog4netLogger类型");
}
}
publicvoidCreateTest()
{
var builder =newContainerBuilder();//构建autofac容器
builder.RegisterModule(newLoggingModule());//注册LoggingModule
builder.RegisterType<Thing>();//注册 Thing类型
var container = builder.Build();//Build 容器
var thing = container.Resolve<Thing>();//从容器中解析 Thing类型
thing.TestMethod();//调用TestMethod方法,则会调用日志
}
Orchard学习 01、orchard日志的更多相关文章
- Orchard 学习-安装Orchard
前段时间使用一个ABP的框架进行了一个简单CMS开发.但感觉自己开发CMS不够灵活和通用,所以还是学习一下Orchard.学习的第一步,阅读官方的文档.由于是英文,所以我对其进行了翻译和记录,方便自己 ...
- 200. Orchard学习 目录
201. Orchard学习 一.基础 210. Orchard学习 二.启动 211. Orchard学习 二 1.Application_Start 212. Orchard学习 二 2.Manu ...
- Orchard学习笔记
1.下载Orchard sourcrs资源文件,同时也可以去百度下载中文包 资源地址(https://github.com/OrchardCMS/Orchard/releases/download/1 ...
- Orchard学习系列-----如何运行的
感慨:当接触到微软这套程序时,代码实在是太好了,好的几乎都读不懂.很久之前就对这个套开源程序特别感兴趣,但读不明白也让人郁闷. 背景(Orchard官网): 可组装系统的CMS系统,OrChard在运 ...
- ThinkPhp学习01
原文:ThinkPhp学习01 一.ThinkPHP的介绍 MVC M - Model 模型 工作:负责数据的操作 V - View 视图(模板 ...
- spring学习(01)之IOC
spring学习(01)之IOC IOC:控制反转——Spring通过一种称作控制反转(IOC)的技术促进了低耦合.当应用了IOC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创 ...
- Python学习--01入门
Python学习--01入门 Python是一种解释型.面向对象.动态数据类型的高级程序设计语言.和PHP一样,它是后端开发语言. 如果有C语言.PHP语言.JAVA语言等其中一种语言的基础,学习Py ...
- Java虚拟机JVM学习01 流程概述
Java虚拟机JVM学习01 流程概述 Java虚拟机与程序的生命周期 一个运行时的Java虚拟机(JVM)负责运行一个Java程序. 当启动一个Java程序时,一个虚拟机实例诞生:当程序关闭退出,这 ...
- Android Testing学习01 介绍 测试测什么 测试的类型
Android Testing学习01 介绍 测试测什么 测试的类型 Android 测试 测什么 1.Activity的生命周期事件 应该测试Activity的生命周期事件处理. 如果你的Activ ...
随机推荐
- Python multiprocessing模块的Pool类来代表进程池对象
#-*-coding:utf-8-*- '''multiprocessing模块提供了一个Pool类来代表进程池对象 1.Pool可以提供指定数量的进程供用户调用,默认大小是CPU的核心数: 2.当有 ...
- kubernetes配置secret拉取私仓镜像
2017.05.10 19:48* 字数 390 阅读 5216评论 0喜欢 8 对于公司内部的项目, 我们不可能使用公有开放的镜像仓库, 一般情况可能会花钱买docker私仓服务, 或者说自己在服务 ...
- python数字转换为字符串的两种方式
主要包括两种形式进行转换: 第一种是str(),将值转换为用户便于阅读的形式: 另一种是repr(),将值转换为合法的python表达式. >>> print repr(" ...
- Scala进阶之路-面向对象编程之类的成员详解
Scala进阶之路-面向对象编程之类的成员详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Scala中的object对象及apply方法 1>.scala 单例对象 ...
- C语言复习---用筛选法求100之内的素数
#include <stdio.h> #include <stdlib.h> #include <math.h> int main() { int i, j; ] ...
- idea2017破解方法
破解方法 切换license server然后 输入网址:http://idea.iteblog.com/key.php即可
- js简单的面试题
1,js有哪些数据类型,数据类型的判断函数? String,Number,Boolean,Null,Undefined,Object 判断函数有:typeof,instanceof,construct ...
- iOS必学技-cocoapods
我就不再造轮子了,网上的教程很详细,楼主亲测,好用. http://code4app.com/article/cocoapods-install-usage 楼主安装使用过程中遇到以下几个问题,同学们 ...
- Linux - 用户操作
常用命令 users # 显示所有的登录用户 groups # 列出当前用户和他所属的组 who -q # 显示所有的登录用户 groupadd # 添加组 useradd user # 建立用户 p ...
- ifconfig,netstat command not found
当CentOS7进行最小化安装时,有很多工具包是没有的. [root@vultr ~]# ifconfig -bash: ifconfig: command not found [root@vultr ...