3

我正在编写一个简单的 Azure 函数。

我已经安装了AzureFunctions.Autofacnuget 包,并希望将其用作我的DI库。

我已经设置了以下AutofacConfig类来注册我的类型:

public class AutofacConfig
{
    public AutofacConfig(string functionName)
    {
        DependencyInjection.Initialize(builder =>
        {
            //do all of you initialization here

            //db client
            builder.RegisterType<EventComponent>()
            .As<IComponent<EventModel>>().SingleInstance(); 
        }, functionName);
    }
}

这是我的EventComponent课程,我想将ILogger提供的实例注入其中。

public class EventComponent : IComponent<EventModel>
{
    private ILogger _log;

    public EventComponent(ILogger logger)
    {
        _log = logger;
    }
}

这是我注入 EventComponent 的方式:

[FunctionName("AddEvent")]
    public static async Task<HttpResponseMessage> Run([HttpTrigger(AuthorizationLevel.Function, "post", Route = null)]HttpRequestMessage req, ILogger log, [Inject]IComponent<EventModel> component)
    {
        log.LogInformation("C# HTTP trigger function processed a request.");

        await component.Add(new EventModel() { Id = Guid.NewGuid(), Description = $"Test description nr: {new Random().Next(1, 100000)}", User = "Test User" });

        return req.CreateResponse(HttpStatusCode.OK);
    }

问题是,我在上面遇到异常,因为Autofac无法解析参数 Microsoft.Extensions.Logging.ILogger。

这是异常消息:

异常绑定参数“组件”...无法解析构造函数“Void .ctor(Microsoft.Extensions.Logging.ILogger)”的参数“Microsoft.Extensions.Logging.ILogger logger”。(有关详细信息,请参阅内部异常。)-> 无法使用可用的服务和参数调用类型为 'Event.Function.Components.EventComponent' 的具有 'Autofac.Core.Activators.Reflection.DefaultConstructorFinder' 的构造函数:\r \n无法解析构造函数 'Void .ctor(Microsoft.Extensions.Logging.ILogger)' 的参数 'Microsoft.Extensions.Logging.ILogger logger'。",

如何将ILogger实例注入我的EventComponent班级?

4

3 回答 3

2

在 Azure Functions V2 中,默认情况下会注入 ILogger。此外,这里有两篇关于 Azure Functions 中的依赖注入的非常好的文章。 https://blog.mexia.com.au/dependency-injections-on-azure-functions-v2

http://codingsoul.de/2018/01/19/azure-function-dependency-injection-with-autofac/

于 2018-08-28T08:39:44.790 回答
0

如果要将 ILogger 注入函数应用程序,则需要执行以下操作:

  1. 将正确的日志级别和命名空间添加到您的 host.json

     {
        "version": "2.0",
        "logging": {
             "applicationInsights": {
                 "samplingSettings": {
                     "isEnabled": true
           }
         },
        "logLevel": {
            "YourNameSpace": "Information"
     }    
    
  2. InjectILogger<T>其中 T 是您的函数应用程序类名称/类型。在此示例中,我的函数应用类名称是 Api。

     public class TestService : ITestService
     {
         private readonly ILogger<Api> _logger;
    
         public TestService(ILogger<Api> logger)
         {
             _logger = logger;
         }
    
         public void LogSomething(string message)
         {
             _logger.LogInformation(message);
         }
     }
    
于 2021-10-06T21:35:14.077 回答
0

我在寻找同样的东西时发现了你的问题。你找到解决办法了吗?

因为我认为这是不可能的。ILogger 日志是由框架注入的,我看不到如何从您的 AutofacConfig 类中引用它。

我如何解决这个问题是通过将 EventComponent-class 更改为使用 Setter-injection 而不是 Constructor-injection,如下所示:

public class EventComponent : IComponent<EventModel>
{
    public ILogger Log { get; set; }    
}

并更改您的功能以设置日志属性:

[FunctionName("AddEvent")]
    public static async Task<HttpResponseMessage> Run([HttpTrigger(AuthorizationLevel.Function, "post", Route = null)]HttpRequestMessage req, ILogger log, [Inject]IComponent<EventModel> component)
    {
        log.LogInformation("C# HTTP trigger function processed a request.");
        component.Log = log;
        await component.Add(new EventModel() { Id = Guid.NewGuid(), Description = $"Test description nr: {new Random().Next(1, 100000)}", User = "Test User" });

        return req.CreateResponse(HttpStatusCode.OK);
    }

缺点是您需要记住在使用该类的每个函数的开头设置该值,但注入有效。

于 2019-03-14T14:01:23.577 回答