首页 > 解决方案 > .Net Core 2.2 AutoFac 注册依赖注入记录器实例

问题描述

工具版本

问题

我正在尝试将记录器实例注入到已配置为 Autofac 进行依赖注入的类中

设置

我有一个查询数据库的类。该类有一个由 Autofac 注入的连接字符串。以下设置有效。

没有注入 Logger 的类:

public class ItemQueries
        : IItemQueries
    {
        private readonly string _connectionString = default(string);

        public ItemQueries(string connectionString)
        {
            _connectionString = !string.IsNullOrWhiteSpace(connectionString) ? connectionString : throw new ArgumentNullException(nameof(connectionString));
        }

        public async Task<ItemViewModel> GetItemAsync(int id)
        {
            using (var connection = new SqlConnection(_connectionString))
            {
                connection.Open();

                var result = await connection.QueryAsync<dynamic>(
                    @"SELECT *                        
                    FROM dbo.items
                    WHERE Id=@id"
                    , new { id }
                );

                if (result.AsList().Count == 0)
                {
                    throw new KeyNotFoundException();
                }

                return MapItem(result.FirstOrDefault());
            }
        }

        private ItemViewModel MapItem(dynamic result)
        {
            return new ItemViewModel()
            {
                Id = result.Id,
                Name = result.Name
            };
        }
    }

这就是我使用 Autofac 注册课程的方式:

public class ItemModule
        : Autofac.Module
    {
        public string QueriesConnectionString { get; }

        public ItemModule(string queriesConnectionString)
        {
            QueriesConnectionString = queriesConnectionString;
        }

        protected override void Load(ContainerBuilder builder)
        {
            builder.Register(c => new ItemQueries(QueriesConnectionString)) // <-- this breaks when I make the below changes because it's looking for an instance of ILogger<ItemQueries>
                .As<IItemQueries>()
                .InstancePerLifetimeScope();
        }
    }

但是,我想将我的 Logger 实例注入到ItemQueries类中,所以我将它注入到构造函数中,如下所示:

private readonly ILogger<ItemQueries> _logger;
private readonly string _connectionString = default(string);

        public ItemQueries(ILogger<ItemQueries> logger, string connectionString)
        {
            _logger = logger;
            _connectionString = !string.IsNullOrWhiteSpace(connectionString) ? connectionString : throw new ArgumentNullException(nameof(connectionString));
        }

但这会破坏我的 Autofac 模块中的注册。如何告诉 AutofacItemQueries该类需要注入 Logger 实例?

我认为 Autofac 将能够锻炼ItemQueries该类需要ILogger<>注入实例(你知道,就像魔术一样!)

标签: c#asp.net-coreautofac

解决方案


您可以在 lambda 注册中解决问题。这就是 lambda 中的 context 参数的用途。

builder
  .Register(c =>
    new ItemQueries(QueriesConnectionString, c.Resolve<ILogger<ItemQueries>>()))
  .As<IItemQueries>()
  .InstancePerLifetimeScope();

推荐阅读