lovebet爱博体育[AOP类别]Autofac+Castle完成AOP日志

一、前言

目前供销合作社新类型,供给搭布局进行付出,个中必要对大器晚成部分日志进行输出,经过生机勃勃番招来,发现众多博文都以透过Spring.Net、Unity、PostSharp、Castle
温泽这个艺术贯彻AOP的。可是那不是小编想要的,因而风华正茂番寻找后,使用Autofac、DynamicProxy该方法实现AOP。

lovebet爱博体育,二、使用AOP的优势

博主感觉它的优势主要表现在:

  • 将通用效能从业务逻辑中分离出来,就足以差相当少多量重复代码,有扶助代码的操作和护卫。
  • 在软件设计时,抽取通用作用(切面卡塔 尔(英语:State of Qatar),有协助软件设计的模块化,减弱软件构造的复杂程度。相当于说通用的功能正是三个单独的模块,在等级次序的主业务里面是看不到那些通用作用的布置性代码的。

三、引用库

  • Autofac:4.6
  • Autofac.Extras.DynamicProxy:4.1.0
  • Castle.Core:3.2.2
  • log4net:2.08

四、达成思路

4.1 切面达成

这里信任自定义的日记组件,配置是不是开启调节和测量检验格局,借使启用调节和测量检验格局,则会输出诉求参数音信以致响应参数新闻。
代码如下:

/// <summary>
/// 日志 拦截器
/// </summary>
public class LoggingInterceptor:IInterceptor
{
    /// <summary>
    /// 日志记录器
    /// </summary>
    private static readonly ILog Logger = Log.GetLog(typeof(LoggingInterceptor));

    public void Intercept(IInvocation invocation)
    {
        try
        {                
            if (Logger.IsDebugEnabled)
            {
                Logger.Caption("日志拦截器-调试信息");
                Logger.Class(invocation.TargetType.FullName);
                Logger.Method(invocation.Method.Name);
                Logger.Params("参数:{0}", invocation.Arguments.ToJson());                    
            }
            invocation.Proceed();
            if (Logger.IsDebugEnabled)
            {
                if (invocation.ReturnValue != null && invocation.ReturnValue is IEnumerable)
                {
                    dynamic collection = invocation.ReturnValue;
                    Logger.Content("结果:行数:{0}", collection.Count);
                }
                else
                {
                    Logger.Content("结果:{0}", invocation.ReturnValue.ToJson());
                }
                Logger.Debug();
            }
        }
        catch (Exception e)
        {
            Logger.Caption("日志拦截器-异常");                
            Logger.Class(invocation.TargetType.FullName);
            Logger.Method(invocation.Method.Name);
            Logger.Params("参数:{0}", invocation.Arguments.ToJson());
            Logger.Exception(e);
            Logger.Error();
            throw;
        }
    }
}

4.3 切面注入

博主对Autofac扩充了打包,只怕与你们的配备不平等,但是,Load(ContainerBuilder builder)该办法内容是相通的,由此注入方式同样的。
由此定义IDependency空中接力口方式,须求注入的类则世袭该接口就能够。
代码如下:

/// <summary>
/// 应用程序IOC配置
/// </summary>
public class IocConfig : ConfigBase
{
    // 重写加载配置
    protected override void Load(ContainerBuilder builder)
    {
        var assembly = this.GetType().GetTypeInfo().Assembly;
        builder.RegisterType<LoggingInterceptor>();
        builder.RegisterAssemblyTypes(assembly)
            .Where(type => typeof(IDependency).IsAssignableFrom(type) && !type.GetTypeInfo().IsAbstract)
            .AsImplementedInterfaces()
            .InstancePerLifetimeScope()
            .EnableInterfaceInterceptors()
            .InterceptedBy(typeof(LoggingInterceptor));
    }
}

五、例子

输出日志如下:
lovebet爱博体育 1
lovebet爱博体育 2

六、相关源码

自定义日志组件可参照他事他说加以调查:JCE.DataCenter.Infrastructure
落到实处日志组件可参照他事他说加以调查:JCE.DataCenter.Logs