原文:.Net Core 3.0 内置依赖注入:举例

版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。

本文根据蔚来汽车.Net 开发部  罗霄老师的分享 进行整理,在这里声明,表示感谢。

本文讲解如何使用.Net Core 3.0的内置依赖(Microsoft.Extensions.DependencyInjection),而不是使用第三方的依赖注入的插件。

实例生命周期的形态:

Transient:容器获取的实例都是全新创建的。使用方法:AddTransient<TClass,Class>

            Scoped:在每次http请求都会创建一个新的实例 AddScoped<TClass,Class> :

            Singleton:单例:始终都是一个实例:AddSingleton<TClass,Class>,

通过一个支付实例来讲解内置依赖:

通过一个简单地下订单和支付来一步步的讲解如何使用内置依赖。

1、使用.net core 3.0 创建一个web项目。

2、选择API程序,.NET Core 3.0,取消HTTS安全协议

3、创建一个Order(下订单)控制器。

4、创建一个参数模型,防止以后修改


  1. namespace Order.Model
  2. {
  3. public class OrderItem
  4. {
  5. public string PayType { get; set; }
  6. }
  7. }

创建一个控制器,并创建一个方法CreateOrder();


  1. namespace Order.Controllers
  2. {
  3. [Route("api/[controller]")]//路由格式
  4. [ApiController]
  5. public class OrderController : ControllerBase
  6. {
  7. [HttpPost]//Post请求
  8. [Route("CreateOrder")]//路由名
  9. public string CreateOrder([FromBody]OrderItem orderItem)//自动匹配参数体
  10. {
  11. return $"我使用{orderItem.PayType}方式支付。";//返回string类型的参数
  12. }
  13. }
  14. }

调用:

返回结果:

5、为实现控制翻转,创建一个接口文件夹和一个实现文件夹,一个IPaymentService接口和两个AliPayService、WechatPayService实现类,并继承接口

接口:


  1. public interface IPaymentService
  2. {
  3. string Pay();
  4. }

实现类:


  1. public class WechatPayService : IPaymentService
  2. {
  3. public string Pay()
  4. {
  5. return "Wechat支付成功";
  6. }
  7. }

  1. public class AliPayService : IPaymentService
  2. {
  3. public string Pay()
  4. {
  5. return "AliPay支付成功";
  6. }
  7. }

6、注册,接口和实现类的注册在startup.cs中的


  1. public void ConfigureServices(IServiceCollection services)
  2. {
  3. services.AddTransient<IPaymentService, WechatPayService>();//注入wechatpay,每次调用都创建一个新的实例
  4. services.AddTransient<IPaymentService, AliPayService>();//注入alipay,每次调用都创建一个新的实例
  5. services.AddControllers();
  6. }

7、通过构造方法进行解析


  1. [Route("api/[controller]")]
  2. [ApiController]
  3. public class OrderController : ControllerBase
  4. {
  5. private readonly IPaymentService _paymentService;
  6. public OrderController(IPaymentService paymentService)
  7. {
  8. _paymentService = paymentService;
  9. }
  10. [HttpPost]
  11. [Route("CreateOrder")]
  12. public string CreateOrder([FromBody]OrderItem orderItem)
  13. {
  14. string payResult = _paymentService.Pay();
  15. return $"我使用{orderItem.PayType}方式支付,支付结果为:{payResult}";
  16. }
  17. }

8、调用测试

这时候就出现错误了,我们明明试行用微信支付,最后调用了alipay的实现类,那么未解决这个问题,我们在接口中定义一个Name属性,用于表示实现类。然后在实现类中将其实现。

9、实现解析不同的类:

添加Name属性


  1. public interface IPaymentService
  2. {
  3. /// <summary>
  4. /// 标识实现类
  5. /// </summary>
  6. public string Name { get; }
  7. string Pay();
  8. }

  1. public class AliPayService : IPaymentService
  2. {
  3. public string Name => "aliPay";
  4. public string Pay()
  5. {
  6. return "AliPay支付成功";
  7. }
  8. }

  1. public class WechatPayService : IPaymentService
  2. {
  3. public string Name => "wechatPay";
  4. public string Pay()
  5. {
  6. return "Wechat支付成功";
  7. }
  8. }

将接口解析为IEnumerable<IPaymentService>

然后再去根据Name,使用Linq去解析特定的支付实现类。然后在调用方法即可


  1. [Route("api/[controller]")]
  2. [ApiController]
  3. public class OrderController : ControllerBase
  4. {
  5. private readonly IEnumerable<IPaymentService> _paymentServiceList;
  6. public OrderController(IEnumerable<IPaymentService> paymentService)
  7. {
  8. _paymentServiceList = paymentService;
  9. }
  10. [HttpPost]
  11. [Route("CreateOrder")]
  12. public string CreateOrder([FromBody]OrderItem orderItem)
  13. {
  14. IPaymentService paymentService = _paymentServiceList.FirstOrDefault(pay => pay.Name == orderItem.PayType);
  15. string payResult = paymentService.Pay();
  16. return $"我使用{orderItem.PayType}方式支付,支付结果为:{payResult}";
  17. }
  18. }

最终测试:

至此,.net Core 3.0内置依赖就实现了。

4、定义一个参数模型,防止参数会不断修改

5、创建一个接口文件夹和一个实现类文件夹,并创建两个接口和两个支付方式(wechat、alipay)

6、使用控制器的构造方法获得支付实例。

7、创建支付接口

.Net Core 3.0 内置依赖注入:举例的更多相关文章

  1. 第四节:配置的读取、StartUp类、内置依赖注入和扩展改造

    一. 配置的读取 在Asp.Net Core中,有一个 appsettings.json 文件,用于存储相应的配置信息,读取的时,要通过构造函数注入:IConfiguration Configurat ...

  2. ASP.NET Core 1.0基础之依赖注入

      来源https://docs.asp.net/en/latest/fundamentals/dependency-injection.html ASP.NET Core 1.0在设计上原生就支持和 ...

  3. 如何在.NET Core控制台程序中使用依赖注入

    背景介绍 依赖注入(Dependency Injection), 是面向对象编程中的一种设计原则,可以用来减低代码之间的耦合度.在.NET Core MVC中 我们可以在Startup.cs文件的Co ...

  4. .NET CORE学习笔记系列(2)——依赖注入【1】控制反转IOC

    原文:https://www.cnblogs.com/artech/p/net-core-di-01.html 一.流程控制的反转 IoC的全名Inverse of Control,翻译成中文就是“控 ...

  5. .NET CORE学习笔记系列(2)——依赖注入[5]: 创建一个简易版的DI框架[下篇]

    为了让读者朋友们能够对.NET Core DI框架的实现原理具有一个深刻而认识,我们采用与之类似的设计构架了一个名为Cat的DI框架.在上篇中我们介绍了Cat的基本编程模式,接下来我们就来聊聊Cat的 ...

  6. .NET CORE学习笔记系列(2)——依赖注入[4]: 创建一个简易版的DI框架[上篇]

    原文https://www.cnblogs.com/artech/p/net-core-di-04.html 本系列文章旨在剖析.NET Core的依赖注入框架的实现原理,到目前为止我们通过三篇文章从 ...

  7. .NET CORE学习笔记系列(2)——依赖注入【2】基于IoC的设计模式

    原文:https://www.cnblogs.com/artech/p/net-core-di-02.html 正如我们在<控制反转>提到过的,很多人将IoC理解为一种“面向对象的设计模式 ...

  8. Spark2.1.0——内置RPC框架详解

    Spark2.1.0——内置RPC框架详解 在Spark中很多地方都涉及网络通信,比如Spark各个组件间的消息互通.用户文件与Jar包的上传.节点间的Shuffle过程.Block数据的复制与备份等 ...

  9. ASP.NET Core - 在ActionFilter中使用依赖注入

    上次ActionFilter引发的一个EF异常,本质上是对Core版本的ActionFilter的知识掌握不够牢固造成的,所以花了点时间仔细阅读了微软的官方文档.发现除了IActionFilter.I ...

随机推荐

  1. Table 'xxx.hibernate_sequence' doesn't exist

    Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'xxx.hibernate_sequence' ...

  2. 前端知识点回顾之重点篇——CSS中的BFC

    BFC布局(Block Formatting Contexts) 来源:https://www.cnblogs.com/lzbk/p/6057097.html 块级格式化上下文是页面中的一块渲染区域, ...

  3. AVQueuePlayer

    想要视频一个接一个的无缝连续播放么? 还在用mpmovieplayercontroller么?out了! 介绍一个可以实现无缝连续播放视频的东西-------AVQueuePlayer ! AVQue ...

  4. 软件-设计-Adobe-Adobe XD:百科

    ylbtech-软件-设计-Adobe-Adobe XD:百科 创建线框.设计.创建原型.展示以及共享适用于 Web.移动设备和语音等的卓越体验 - 以上操作在一款应用程序中即可完成.XD 面向需要进 ...

  5. Python3+RobotFramewok 循环判断以及Evaluate用法(三)

    本章主要介绍RF的循环,判断以及关键字Evaluate. 1. for循环 在RF中通过 :FOR 编写循环 :FOR ${i} in range 10 log ${i} @{list} create ...

  6. 转 layer的Icon样式以及一些常用的layer窗口使用

    转载地址:http://blog.csdn.net/beauxie/article/details/60959971 本文搜集的是本人在实际开发中所用到的layer窗口,未用到的layer按钮,请参考 ...

  7. 014-数据结构-树形结构-基数树、Patricia树、默克尔树、梅克尔帕特里夏树( Merkle Patricia Tree, MPT)

    一.基数树 Radix树,即基数树,也称压缩前缀树,是一种提供key-value存储查找的数据结构.与Trie不同的是,它对Trie树进行了空间优化,只有一个子节点的中间节点将被压缩.同样的,Radi ...

  8. Turbine Netflix

    Turbine是聚合服务器发送事件流数据的一个工具,用来监控集群下hystrix的metrics情况. 本实例是在consul做为服务发现时的配置. Turbine聚合器: 可以参照:https:// ...

  9. 5.Linux文件权限

    Linux用户类别 root:这是系统特权用户类,他们都有访问root登录账号的权限 owner:这是实际拥有文件的用户 group:这是共享文件的组访问权的用户类的用户组名称 world:这是不属于 ...

  10. RocketMQ之九:RocketMQ消息发送流程解读

    在讨论这个问题之前,我们先看一下Client的整体架构. Producer与Consumer类体系 从下图可以看出以下几点:(1)Producer与Consumer的共同逻辑,封装在MQClientI ...