前言
.net core自带DI(包括Autofac)的常规用法:每写一个接口就需要注册一次,以备在使用时自动注入实例。
在写常规代码时这样重复的步骤过于繁琐,这里介绍在切面层一劳永逸的做法。
1、.net core 自带DI(属性的形式定义声明周期)
步骤一:添加属性,并含有生命周期的参数;
步骤二:给接口实现类添加该属性,并定义生命周期;
步骤三:在ConfigureServices中利用反射找到所有的类,并根据属性定义的生命周期来注册;
2、.net core 自带DI(接口的形式定义声明周期)
步骤一:添加三个空接口,代表三种生命周期;
步骤二:实现类继承所需生命周期的接口;
步骤三:在ConfigureServices中利用反射找到所有的类,并根据实现类所继承的接口代表的生命周期来注册;
3、Autofac
步骤一:引入包Autofac.Extensions.DependencyInjection,并初始化Autofac;
步骤二:添加ConfigureContainer方法,它会在Configure方法执行后执行,这里是通过属性的形式定义声明周期来注册;(属性定义如上,也可用接口的形式如上)
总结:
1)上述三种做法都能在切面层做到批量注入,做到最少的侵入代码;
2)之所以采用定义属性或者接口的方式,是为了更好的定义生命周期,如果项目中只需要一种生命周期的话,可以连属性和接口都不用,直接使用某一种生命周期(Autofac默认是Transient);
3)利用反射取所有类型时,用的是AppDomain.CurrentDomain.GetAssemblies().SelectMany(x => x.GetTypes()),如果是多项目分层的话要替换成Assembly.GetEntryAssembly().GetReferencedAssemblies().Select(Assembly.Load).SelectMany(x => x.DefinedTypes);
参考:https://stackoverflow.com/questions/42524704/asp-net-core-find-all-class-types-in-all-assemblies
4)Autofac相对.net core自带DI来说还能带来更多便利,参考上述截图中的ConfigureContainer方法里注释掉的地方,还可与Castle结合起来用,在下一篇.net core 批量拦截器中会详细讲到;
5)使用的环境是.net core 3.x,由于Autofac每个版本的写法有一些变化,建议先对照一下版本后使用对应的写法;