受欢迎的博客标签

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

Published

http://www.cnblogs.com/Wddpct/p/7219205.html 

我们都知道,在 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;
}