当我写回复时,Katana会跳过发送Elapsed-Time响应头。在我第一次写入流之前,如何让它为我设置标题?
public override async Task Invoke(IOwinContext context)
{
var stopwatch = new Stopwatch();
stopwatch.Start();
await Next.Invoke(context);
stopwatch.Stop();
context.Response.Headers.Add("Elapsed-Time", new[] {stopwatch.ElapsedMilliseconds.ToString()});
}
public override async Task Invoke(IOwinContext context)
{
await context.Response.WriteAsync("test");
}
答案 0 :(得分:11)
经过一些研究,答案是设置标题需要在OnSendingHeaders中发生。这可确保在写入输出流之前设置标头。例如:
public override async Task Invoke(IOwinContext context)
{
var stopwatch = new Stopwatch();
context.Response.OnSendingHeaders(x =>
{
stopwatch.Stop();
context.Response.Headers.Add("X-Processing-Time", new[] {stopwatch.ElapsedMilliseconds.ToString()});
}, null);
stopwatch.Start();
await Next.Invoke(context);
stopwatch.Stop();
}
答案 1 :(得分:2)
使用Response
' Headers
属性。
public override async Task Invoke(IOwinContext context)
{
context.Response.Headers.Add("Content-Length", <somelength>);
await context.Response.WriteAsync("test");
}
<强>更新强>
您的中间件看起来是正确的。也许,您在配置中遇到问题。
检查,如果你已经像这样管道你的中间人:
app.Use(typeof(MiddlewareOne))
.Use(typeof(MiddlewareTwo));
顺便说一句,你不需要两个midlewares。这将作为墙:
public class MyMiddleware : OwinMiddleware
{
public MyMiddleware(OwinMiddleware next)
: base(next)
{}
public override async Task Invoke(IOwinContext context)
{
var stopwatch = new Stopwatch();
stopwatch.Start();
await context.Response.WriteAsync("test");
stopwatch.Stop();
context.Response.Headers.Add("Elapsed-Time", new[] {stopwatch.ElapsedMilliseconds.ToString()});
}
}
并且配置为:
app.Use(typeof(MyMiddleware));