C#-Asp.net核心-invokeMethod()在中间件中未调用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了C#-Asp.net核心-invokeMethod()在中间件中未调用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1592字,纯文字阅读大概需要3分钟。
内容图文
我熟悉中间件概念,并且在我的项目中实现了许多中间件.我也阅读了Microsoft文档中的ASP.NET Core Middleware文档.但是这一次我遇到了令人困惑的问题,实际上,我编写了一个简单的中间方法来为每个请求编写日志.
这是我的中间件类:
public class LoggerMiddleware
{
private readonly RequestDelegate _next;
public LoggerMiddleware(RequestDelegate next)
{
_next = next;
}
public async Task Invoke(HttpContext httpContext, LogDbContext dbContext)
{
var logInfo = await Logger.InitiateLogging(httpContext, dbContext);
try
{
await _next(httpContext);
}
catch (Exception ex)
{
await Logger.AddException(httpContext, ex, true);
}
finally
{
await Logger.PersistLog(logInfo, httpContext);
}
}
}
然后,我声明了一种扩展方法:
public static class LoggingMiddlewareExtensions
{
public static IApplicationBuilder UseLogger(this IApplicationBuilder builder)
{
return builder.UseMiddleware<LoggerMiddleware>();
}
}
最后,我在Startup.cs上的Configure上调用UseLogger方法.
这是我的startup.cs代码:
public void Configure(
IApplicationBuilder app,
IHostingEnvironment env,
ILoggerFactory loggerFactory,
IServiceScopeFactory scopeFactory,
IOptions<BaranSettings> baranSettings)
{
loggerFactory.AddConsole(Configuration.GetSection("Logging"));
loggerFactory.AddDebug();
// other lines of code...
app.UseLogger();
// other lines of code...
}
问题:
问题是调用了LoggerMiddleware构造函数,但是没有调用Invoke方法.
有谁知道这是什么问题吗?
解决方法:
对于此特定用例,我强烈建议您考虑使用.Net Core DI并注入ILoggerFactory:
Why ASP.NET Core DI knows how to resolve ILogger
也可以看看:
How to Use LoggerFactory and Microsoft.Extensions.Logging for .NET Core Logging With C#
内容总结
以上是互联网集市为您收集整理的C#-Asp.net核心-invokeMethod()在中间件中未调用全部内容,希望文章能够帮你解决C#-Asp.net核心-invokeMethod()在中间件中未调用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。