前言

.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每个版本的写法有一些变化,建议先对照一下版本后使用对应的写法;

内容来源于网络如有侵权请私信删除

文章来源: 博客园

原文链接: https://www.cnblogs.com/willardzmh/p/14393696.html

你还没有登录,请先登录注册
  • 还没有人评论,欢迎说说您的想法!