0

我正在使用 ASP.NET Core 2.1 和 NLog。如果我在 StartUp 中添加一个依赖于 ILoggerFactory 的构造函数,它会将其解析为与我在 Configure 方法中获得的实例不同的实例。在 Configure 方法中,我调用了 AddNLog,因为它是一个不同的实例,所以我在 ConfigureServices 中使用的实例还没有为 NLog 做好准备。

任何想法如何在 ConfigureService 中访问 ILoggerFactory 并在 Configure 中拥有相同的实例以便我可以调用 AddNLog?在 ConfigureServices 中调用 AddNLog 不起作用。

4

2 回答 2

0

我通过在应用程序启动事件中注册一些代码来解决它。

在配置方法中:

            appLifetime.ApplicationStarted.Register(() =>
            {
                InitializeSingletonObjects(app, loggerFactory);
            });

此时一切都已正确初始化,您可以在 InitializeSingletonObjects 中做任何您想做的事情。就我而言,这就是我所做的。

        private void InitializeSingletonObjects(IApplicationBuilder app, ILoggerFactory loggerFactory)
        {
            // email template processor
            var emailRepository = app.ApplicationServices.GetService<IEmailRepository>();
            IEmailTemplateProcessor emailTemplateProcessor = app.ApplicationServices.GetService<IEmailTemplateProcessor>();
            string containerName = appConfiguration.AzureBlobStorage.BlobStorageContainerEmailTemplates;
            var emailTemplates = emailRepository.GetEmailTemplates(true);

            emailTemplateProcessor.Initialize(containerName, emailTemplates);
        }

有关 IApplicationLifetime 的更多信息,请访问https://www.khalidabuhakmeh.com/looking-at-asp-net-cores-iapplicationlifetime

于 2018-07-19T12:39:35.083 回答
0

我不确定我是否理解了这个问题,但你不能按照这里的解释做:

public void Configure(IApplicationBuilder app, IHostingEnvironment env, 
ILoggerFactory loggerFactory)
{
    //...
    loggerFactory.AddLog4Net(); // << Add this line
于 2018-07-19T08:40:27.057 回答