.NET CORE-通过内置IOC容器IServiceCollection进行服务注册

  • 第一种方式:
  1. 在Startup中的ConfigureServices方法中注册服务:
    services.AddTransient<ITestServiceA, TestServiceA>();
  2. 在控制器中通过构造函数进行注入:
    private readonly ITestServiceA _ITestServiceA = null;
    public HomeController(ITestServiceA testServiceA)
    {
           _ITestServiceA = testServiceA;
    }
  3. 之后即可进行调用
    public IActionResult Index()
    {
           _ITestServiceA.Show();
           return View();
    }
  • 第二种方式:
  1. 仍然先在Startup中的ConfigureServices方法中注册服务:
    services.AddTransient<ITestServiceA, TestServiceA>();
  2. 在控制器中通过构造函数,注入IServiceProvider:
    private readonly IServiceProvider _ServiceProvider = null;
    public HomeController(IServiceProvider serviceProvider)
    {
          _ServiceProvider = serviceProvider;
    }
  3. 通过_ServiceProvider获取到服务,然后通过服务实例调用服务内部的方法:
    public IActionResult Index()
    {
         ITestServiceB _ITestServiceB = (ITestServiceB)_ServiceProvider.GetService(typeof(ITestServiceB));
         _ITestServiceB.ShowB();
         return View();
    }
  • 第三种方式:
  1. 还是先注册服务:
    services.AddTransient<ITestServiceA, TestServiceA>();
  2. 然后在视图中通过关键字@Inject获取实例
    @using CoreInterface
    @inject ITestServiceA itestserviceA
    @{ 
        itestserviceA.Show();
    }
posted @   dreamw  阅读(48)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
历史上的今天:
2021-06-17 mysql删除表编码字段_mysql中修改表的默认编码和表中字段的编码
2021-06-17 java.sql.SQLException: Illegal mix of collations (utf8mb4_general_ci,IMPLICIT) and (utf8mb4_0900_ai_ci,IMPLICIT) for operation '='
点击右上角即可分享
微信分享提示