ПО промежуточного слоя Serilog Owin

Я пытаюсь добавить простое обогащение, используя LogContext в конвейере Owin

Конфигурация My Logger

// 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.

Что я делаю неправильно?


person Omri Btian    schedule 13.03.2017    source источник


Ответы (1)


Очевидно, это связано с этой проблемой. Обходной путь, который сработал для меня, - это изменение порядка конвейера owin и размещение промежуточного программного обеспечения для ведения журнала после аутентификации.

AuthConfig.Configure(app);
LogConfig.Configure(app);
WebApiConfig.Configure(app);
person Omri Btian    schedule 13.03.2017