.NET CORE——Console中使用依赖注入

我们都知道,在 ASP.NET CORE 中通过依赖注入的方式来使用服务十分的简单,而在 Console 中,其实也只是稍微绕了个小弯子而已。不管是内置 DI 组件或者第三方的 DI 组件(如Autofac),通过 IServiceCollection 接口我们都可以做到和应用程序的无缝连接。本文将在别给出内置组件和第三方组件(主要是Autofac)在 Console 应用程序中的依赖注入实现方式。

1. 在 Console 中使用内置 DI 组件

  • 网上已经有几篇相关的博客讲解 Console 中的依赖注入,链接都会附于文章末尾。不像 ASP.NET CORE 在应用框架启动时便将 DI 容器初始化完成并且注入了大部分开发者需要的服务,我们只能从零开始。
// 安装 DI 组件
Install-Package Microsoft.Extensions.DependencyInjection
// 安装日志输出组件
Install-Package Microsoft.Extensions.Logging.Console
  • 添加模拟的应用服务
public interface ICounterAppService
{
    void Count(int loops);
}

public class CounterAppService : ICounterAppService
{
    private readonly ILogger _logger;

    public CounterAppService(ILoggerFactory logger)
    {
        _logger = logger.CreateLogger<CounterAppService>();
    }

    public void Count(int loops)
    {
        for (var i = 0; i < loops; i++)
            _logger.LogInformation($"We have got the {i} Loop");
    }
}
  • Program 中对 DI 组件的初始化和服务的注册
private static void Main(string[] args)
{
    var serviceProvider = new ServiceCollection()
        .AddLogging()
        .AddSingleton<ICounterAppService, CounterAppService>()
        .BuildServiceProvider();

    serviceProvider
        .GetService<ILoggerFactory>()
        .AddConsole(LogLevel.Debug);

    var logger = serviceProvider.GetService<ILoggerFactory>()
        .CreateLogger<Program>();
    logger.LogDebug("Starting application");

    var counter = serviceProvider.GetService<ICounterAppService>();
    counter.Count(10);

    logger.LogDebug("All done!");
}

我们手动创建 serviceProvider 的过程其实就是 ASP.NET CORE 执行 ConfigureServices 方法的过程,同样的,上述代码也展示了手动解析 Logger 实例和通过构造函数注入解析 Logger 实例的两种方式。其中 AddLogging 方法的背后代码如下所示:

public static IServiceCollection AddLogging(this IServiceCollection services)
{
  if (services == null)
    throw new ArgumentNullException("services");
  services.TryAdd(ServiceDescriptor.Singleton<ILoggerFactory, LoggerFactory>());
  services.TryAdd(ServiceDescriptor.Singleton(typeof (ILogger<>), typeof (Logger<>)));
  return services;
}

2. 在 Console 中使用第三方 Autofac DI 组件

笔者曾经写过在 ASP.NET CORE 使用 Autofac 组件的例子,而在 Console 中,注册流程也没有什么变化。以下是 Program 中的代码

private static void Main(string[] args)
{
    var serviceCollection = new ServiceCollection();
    
    serviceCollection.AddLogging();

    var containerBuilder = new ContainerBuilder();
    
    // 将原本注册在内置 DI 组件中的依赖迁移入 Autofac 中
    containerBuilder.Populate(serviceCollection);
    
    // 也可以把 ICounterAppService 预先注入到内置 DI 中再使用 Populate 方法迁移
    containerBuilder.RegisterType<CounterAppService>().As<ICounterAppService>();
    
    var container = containerBuilder.Build();
    var serviceProvider = new AutofacServiceProvider(container);
    
    serviceProvider
        .GetService<ILoggerFactory>()
        .AddConsole(LogLevel.Debug);

    var logger = serviceProvider.GetService<ILoggerFactory>()
        .CreateLogger<Program>();
    logger.LogDebug("Starting!");

    var counter = serviceProvider.GetService<ICounterAppService>();
    counter.Count(10);

    logger.LogDebug("Done!");
}

同时,Autofac中也提供了诸如 RegisterAssemblyTypes 的方法用于程序集中服务的批量注入,这也是第三方容器的优势所在。

Using dependency injection in a .Net Core console application
ASP.NET Core Dependency Injection Deep Dive

转载于:https://www.cnblogs.com/Wddpct/p/7219205.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
.NET Core WebAPI 进行依赖注入 Elasticsearch,您需要按照以下步骤进行操作: 1. 首先,您需要在 WebAPI 项目安装 Elasticsearch 的 .NET 客户端,您可以使用 NuGet 包管理器来安装。 2. 在 WebAPI 项目定义 Elasticsearch 的客户端服务,以便在应用程序注入 Elasticsearch 客户端依赖项。您可以在 Startup.cs 文件的 ConfigureServices 方法注册 Elasticsearch 客户端服务。 3. 建立 Elasticsearch 客户端连接,以便在 WebAPI 项目使用 Elasticsearch 客户端进行数据检索。您可以在 Startup.cs 文件的 Configure 方法创建 Elasticsearch 客户端连接。 以下是示例代码: ```csharp // 1. 安装 Elasticsearch 的 .NET 客户端 // Install-Package Nest // 2. 定义 Elasticsearch 客户端服务 public void ConfigureServices(IServiceCollection services) { // 添加 Elasticsearch 的 .NET 客户端服务 services.AddSingleton<IElasticClient>(s => { var settings = new ConnectionSettings(new Uri("http://localhost:9200")); return new ElasticClient(settings); }); } // 3. 建立 Elasticsearch 客户端连接 public void Configure(IApplicationBuilder app, IWebHostEnvironment env, IElasticClient elasticClient) { // 建立 Elasticsearch 客户端连接 var response = elasticClient.Ping(); if (!response.IsValid) { // 处理连接失败的情况 } } ``` 在您注册了 Elasticsearch 客户端服务之后,您可以通过构造函数注入 IElasticClient 接口来使用 Elasticsearch 客户端。例如,如果您要在控制器使用 Elasticsearch 客户端进行数据检索,您可以按照以下方式进行操作: ```csharp [ApiController] [Route("[controller]")] public class MyController : ControllerBase { private readonly IElasticClient _elasticClient; public MyController(IElasticClient elasticClient) { _elasticClient = elasticClient; } [HttpGet] public async Task<IActionResult> Get() { var response = await _elasticClient.SearchAsync<MyDocument>(s => s .Index("myindex") .From(0) .Size(10) .Query(q => q.MatchAll()) ); if (!response.IsValid) { // 处理数据检索失败的情况 } return Ok(response.Documents); } } ``` 在上面的示例,我们注入了 IElasticClient 接口,并在 Get 方法使用它来执行数据检索操作。您可以根据实际情况使用不同的 Elasticsearch 客户端 API,例如 Index、Update、Delete 等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值