Serilog Owin中间件

时间:2017-03-13 15:14:02

标签: c# logging 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));

My 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

我做错了什么?

1 个答案:

答案 0 :(得分:2)

这显然与this issue有关。 对我有用的解决方法是更改​​owin管道的顺序并在验证后放置日志记录中间件

AuthConfig.Configure(app);
LogConfig.Configure(app);
WebApiConfig.Configure(app);