如何解决自定义日志记录,无需Consumructor DI
如何在每个类中基于未注册具有构造函数依赖项注册的提供程序记录自定义信息/错误? (因为我在控制器内部调用了单个控制器多个存储库,而我无法更改存储库的构造类)
例如,我想在不涉及控制器构造函数的情况下在以下上下文中记录信息
public override void OnException(ExceptionContext context)
{
base.OnException(context);
var logger = Dependency.Resolve<ILogger>();
**//var logger = getIloggerSomehow from startup regsistred loggers**
logger.LogInformation("Custom Info");
}
我的启动服务如下所示,它在我期望的任何地方写入dotnet和Microosft日志。 我如何在所有这些地方编写自定义日志?
services.AddLogging(loggingBuilder =>
{
loggingBuilder.AddConfiguration(Configuration.GetSection("Logging")); loggingBuilder.AddAWSProvider(Configuration.GetAWSLoggingConfigSection());
loggingBuilder.SetMinimumLevel(LogLevel.Debug);
loggingBuilder.AddConsole();
loggingBuilder.AddDebug();
});
解决方法
您可以通过context
方法中的OnException
来解析服务:
using Microsoft.Extensions.DependencyInjection;
...
var service = context.HttpContext.RequestServices.GetService<ILogger<YourFilter>>();
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。