using Microsoft.AspNetCore.Http; using System.Diagnostics; namespace LiveForum.Code.MiddlewareExtend { /// /// 方法执行时间 /// public class ExecutionTimeMiddleware(RequestDelegate _next) { public async Task Invoke(HttpContext context) { // 开始计时 var sw = Stopwatch.StartNew(); //在将响应标头发送到之前添加要调用的委托客户此处注册的回调按相反顺序运行。 if (!context.Response.HasStarted) { context.Response.OnStarting(() => { sw.Stop(); context.Response.Headers.TryAdd("X-Request-Duration", $"{sw.Elapsed.TotalMilliseconds} ms"); return Task.CompletedTask; }); } else { sw.Stop(); } await _next(context); } } }