net core WebApi——依赖注入Autofac

目录

  • 前言
  • Autofac
  • 添加一个Util来随时调用
  • 小结
  • 代码地址
  • 预告

前言

周末加班,下午犯困,整理下之前鼓捣过的东西,看过我之前的webapi系列的读者知道,我之前试过Aspect,但是升级到3.0之后没往下去试了,当时还留了个坑,这不,现在果断移除了换成这个了。

Autofac

这个第三方类库呢,是Ioc的容器,可以简化我们很大的工作量,比如说在之前我们需要写个类去声明接口与实现,而用了这个容器呢,就不需要了,当然还是需要些配置的。

首先,引入第三方类库,不多说。

然后开始配置吧,首先先来看Program,添加AutofacServiceProviderFactory

        public static IHostBuilder CreateHostBuilder(string[] args) =>
            Host.CreateDefaultBuilder(args)
                .ConfigureWebHostDefaults(webBuilder =>
                {
                    webBuilder.UseStartup<Startup>();
                })
                .UseServiceProviderFactory(new AutofacServiceProviderFactory());

改完之后呢,我们果断就来到了Startup,只要是配置,当然要看入口文件跟这个配置文件了。

3.x呢有个变化就是Autofac要通过ConfigureContainer这个传入容器的方法来配置了,不需要自己再创建。

        private static readonly List<string> _Assemblies = new List<string>()
        {
            "April.Service"
        };
        public void ConfigureContainer(ContainerBuilder container)
        {
            var assemblys = _Assemblies.Select(x => Assembly.Load(x)).ToList();
            List<Type> allTypes = new List<Type>();
            assemblys.ForEach(aAssembly =>
            {
                allTypes.AddRange(aAssembly.GetTypes());
            });

            // 通过Autofac自动完成依赖注入
            container.RegisterTypes(allTypes.ToArray())
                .AsImplementedInterfaces()
                .PropertiesAutowired()
                .InstancePerDependency();

            // 注册Controller
            container.RegisterAssemblyTypes(typeof(Startup).GetTypeInfo().Assembly)
                .Where(t => typeof(Controller).IsAssignableFrom(t) && t.Name.EndsWith("Controller", StringComparison.Ordinal))
                .PropertiesAutowired();
        }

通过RegisterTypes的注册方法将对应工程,也就是April.Service下的类接口与实现自动绑定,当然你也可以通过注册接口的方法一个个来,但是我懒,比如:

// 一个
builder.RegisterType<StudentService>().As<IStudentService>();
// 一对多
builder.RegisterType<StudentService>().As<IStudentService>().As<ITestService>();

这里注意,声明绑定一般是一对一,当然也可以是一对多,如果多次注册声明一个类,会取最后一次注册的声明作为实际操作的类。

好了,配置完成之后,我们来试下效果吧(当然我是已经注释掉之前的ServiceInjection这个声明方法了)。

在我们访问Values的时候,我们看下IStudentService是否是null。

OK,这已经说明通过Autofac这个容器,已经完成了一个工程里面的接口与实现的依赖关系了。

添加一个Util来随时调用

在接触的朋友中,有人给我反馈个信息,我不想每次写方法都要构造函数来传接口方法给我,也就是说我不要你觉得,我要我觉得。

好啊,你觉得方法自己要啥拿啥,可以,来个Util吧。

    public class AutofacUtil
    {
        public static ILifetimeScope Container { get; set; }

        /// <summary>
        /// 获取服务(Single)
        /// </summary>
        /// <typeparam name="T">接口类型</typeparam>
        /// <returns></returns>
        public static T GetService<T>() where T : class
        {
            return Container.Resolve<T>();
        }

        /// <summary>
        /// 获取服务(请求生命周期内)
        /// </summary>
        /// <typeparam name="T">接口类型</typeparam>
        /// <returns></returns>
        public static T GetScopeService<T>() where T : class
        {
            return (T)GetService<IHttpContextAccessor>().HttpContext.RequestServices.GetService(typeof(T));
        }
    }

在用之前,我们需要针对Container来个声明实例化,Startup中的Configure添加下面一句。

            AutofacUtil.Container = app.ApplicationServices.GetAutofacRoot();

修改Values中的一部分来通过实例化的方式来调用接口。

            IStudentService studentService = AutofacUtil.GetScopeService<IStudentService>();

            StudentEntity entity = new StudentEntity
            {
                //新增
                Name = "小明",
                Age = 18,
                Number = "007",
                Sex = 0,
                Address = "大洛阳"
            };

            studentService.Insert(entity);

让我们来看下效果吧。

两种方法,看个人习惯吧,我是推荐通过注入的方式,通过构造函数的方式来获取接口实现。

小结

简单记录平时鼓捣的点点滴滴,有时候真是觉得,还是要多看多鼓捣,就像这个容器,在之前我通过一行一行的接口+实现来做绑定声明,现在呢,只需要改造下,就可以一键无脑实例化,第三方库的使用与否,个人觉得还是能踩着巨人的肩膀哪怕靠着也可以,自己一步步爬固然可嘉,也要学会变通,这样方能提高效率,路漫漫其修远兮

代码地址

注意切换到3.0的分支。
github
gitee

预告

April-Admin,总算是要有个前后端联动的工程了,一个名副其实的基础工程。

前端基于Ant Design Pro
后端当然是net core 3.1

原文地址:https://www.cnblogs.com/AprilBlank/p/12111733.html

时间: 2024-12-05 17:40:10

net core WebApi——依赖注入Autofac的相关文章

AutoFac实现WebAPI依赖注入(EF以及Mysql)

什么是依赖注入? 我们以实际的例子来加以介绍 实体如下 public class Product { public int ID { get; set; } public string Name { get; set; } public decimal Price { get; set; } } EF的实现如下 public class ProductContext: DbContext { public ProductContext(): base( "ProductContext"

.Net Core 使用依赖注入

ASP.NET Core 源码阅读笔记(1) ---Microsoft.Extensions.DependencyInjection 在asp .net中使用依赖注入很简单,只需要在Startup类的ConfigureServices(IServiceCollection services)方法中,通过IServiceCollection接口注入就行. 通过接口的Add*方法进行注册,代码如下: ASP.NET Core runtime帮忙注册如下方法 // This method gets c

用工厂模式解决ASP.NET Core中依赖注入的一个烦恼

这是最近在实际开发中遇到的一个问题,用 asp.net core 开发一个后端 web api ,根据指定的 key 清除 2 台 memcached 服务器上的缓存.背景是我们在进行 .net core 迁移工作,asp.net 项目与 asp.net core 项目并存,为了避免两种类型项目的缓存冲突,我们分别用了 2 台不同的 memcached 服务器. 之前使用 1 台 memcached 服务器时,只需要一个客户端,所以只需创建一个 MemcachedClient 单例并注入到 IM

【ASP.NET Core】依赖注入高级玩法——如何注入多个服务实现类

依赖注入在 ASP.NET Core 中起中很重要的作用,也是一种高大上的编程思想,它的总体原则就是:俺要啥,你就给俺送啥过来.服务类型的实例转由容器自动管理,无需我们在代码中显式处理. 因此,有了依赖注入后,你的编程思维就得变一变了.在过去,许多功能性的类型(比如一个加密解密的类),我们都喜欢将其定义为静态(static),而有了依赖注入,你就要避免使用静态类型,应该交由服务容器帮你管理,只要你用好了,你会发现依赖注入是很方便的. 依赖注入的初级玩法,也是比较标准的玩法,此种玩法有两种模式:

Catel帮助手册-Catel.Core:(5)依赖注入(ServiceLocator and TypeFactory)

1,简介 在Catel2.0之前,IOC容器内部使用的是Unity,然而,这就强制所有的用户在他的应用程序中使用Unity作为IOC容器,也需要这样划分库,从2.0以后,一个不同的技术被使用了,这个允许开发者可以使用他们自己悬着的IOC容器技术. 1.1在Ioc中不同的组件 在Catel中有许多不同的组件他们对于Ioc是非常重要的. ServiceLocator 该组件用于注册所有的类型,这个事真正的Ioc容器 TypeFactory 用于创建类型的组件,使用IServiceLocator来获取

.NET Core 中依赖注入 AutoMapper 小记

最近在 review 代码时发现同事没有像其他项目那样使用 AutoMapper.Mapper.Initialize() 静态方法配置映射,而是使用了依赖注入 IMapper 接口的方式 services.AddSingleton<IMapper>(new Mapper(new MapperConfiguration(cfg => { cfg.CreateMap<User, MentionUserDto>(); }))); 于是趁机学习了解一下,在 github 上发现了 A

基于 ASP.NET Core 2.0 WebAPI 后台框架搭建(1) - 依赖注入三层框架搭建

概述 本文章描述如何搭建 ASP.NET Core 2.0 WebAPI 依赖注入三层架构,为什么要加入依赖,并不是为了提供程序性能,而是为了项目间解耦,项目之间能够更加独立. 微软爸爸官方说明文档:在 ASP.NET Core 依赖注入 全面理解 ASP.NET Core 依赖注入 步骤 1. 新建解决方案,添加一个ASP.NET Core WebApi应用 2. 添加四个.Net Core类库:Entity.BLL.DAL.Common 3. 按照以下截图进行解决方案布局 4. 添加DAL层

asp.net core 系列之Dependency injection(依赖注入)

这篇文章主要讲解asp.net core 依赖注入的一些内容. ASP.NET Core支持依赖注入.这是一种在类和其依赖之间实现控制反转的一种技术(IOC). 一.依赖注入概述 1.原始的代码 依赖就是一个对象的创建需要另一个对象.下面的MyDependency是应用中其他类需要的依赖: public class MyDependency { public MyDependency() { } public Task WriteMessage(string message) { Console

Asp.Net.Core 系列-中间件和依赖注入进阶篇

上一节讲了中间件和依赖注入的基础,紧接着: 中间件是怎么使用的?使用步骤是什么? 只要把中间件注册到管道中就行了,可以借助Startup对象(DelegateStartup或者ConventionBasedStartup)来完成之外,也可以利用另一个叫做StartupFilter的对象来实现.所谓的StartupFilter是对所有实现了IStartupFilter接口的类型及其对象的统称.IStartupFilter接口定义了如下一个唯一的方法Configure,该方法的参数next返回的Ac