Serilog Owin 中间件
Serilog Owin Middleware
我正在尝试在 Owin 管道中使用 LogContext
添加一个简单的扩充
我的记录器配置
// configure logger
Log.Logger = new LoggerConfiguration()
.Enrich.WithProperty("B", 2)
.ReadFrom.AppSettings()
.Enrich.FromLogContext()
.CreateLogger();
app.Use(typeof(LoggerMiddleware));
我的 Owin 中间件
public class LoggerMiddleware : OwinMiddleware
{
public LoggerMiddleware(OwinMiddleware next) : base(next)
{
}
public override async Task Invoke(IOwinContext context)
{
using (LogContext.PushProperty("A", 1))
{
await Next.Invoke(context);
}
}
}
在日志中我可以看到 属性 B, 2
但看不到 A, 1
.
我做错了什么?
很明显,这与 this issue 有关。
对我有用的解决方法是更改 owin 管道的顺序并在身份验证之后放置日志记录中间件
AuthConfig.Configure(app);
LogConfig.Configure(app);
WebApiConfig.Configure(app);
我正在尝试在 Owin 管道中使用 LogContext
添加一个简单的扩充
我的记录器配置
// configure logger
Log.Logger = new LoggerConfiguration()
.Enrich.WithProperty("B", 2)
.ReadFrom.AppSettings()
.Enrich.FromLogContext()
.CreateLogger();
app.Use(typeof(LoggerMiddleware));
我的 Owin 中间件
public class LoggerMiddleware : OwinMiddleware
{
public LoggerMiddleware(OwinMiddleware next) : base(next)
{
}
public override async Task Invoke(IOwinContext context)
{
using (LogContext.PushProperty("A", 1))
{
await Next.Invoke(context);
}
}
}
在日志中我可以看到 属性 B, 2
但看不到 A, 1
.
我做错了什么?
很明显,这与 this issue 有关。 对我有用的解决方法是更改 owin 管道的顺序并在身份验证之后放置日志记录中间件
AuthConfig.Configure(app);
LogConfig.Configure(app);
WebApiConfig.Configure(app);