0

0

ASP.NET Core中间件怎么编写 自定义Middleware管道方法

月夜之吻

月夜之吻

发布时间:2025-12-27 14:33:10

|

204人浏览过

|

来源于php中文网

原创

ASP.NET Core中间件是按顺序处理HTTP请求响应的组件,可写为lambda委托或封装成带依赖注入的类,注册顺序决定执行逻辑,需注意短路、前置/后置时机及Options配置。

asp.net core中间件怎么编写 自定义middleware管道方法

ASP.NET Core 中间件就是处理 HTTP 请求和响应的组件,按顺序组成管道。自定义中间件本质是一个接收 RequestDelegate(下一个中间件)并返回 Task 的委托,或封装成类更清晰、可复用。

写一个基础函数式中间件

最简方式是直接在 Program.cs 中用 lambda 编写:

app.Use(async (context, next) =>
{
    // 在下一个中间件执行前做的事(前置逻辑)
    Console.WriteLine("请求开始");

    await next(); // 调用管道中的下一个中间件

    // 在下一个中间件执行后做的事(后置逻辑)
    Console.WriteLine("请求结束");
});

注意:必须调用 next() 才能让请求继续向下走;不调用就“短路”了(比如做身份验证失败直接返回 401)。

封装成可重用的中间件类

推荐做法,利于测试、配置和复用。例如写一个记录请求耗时的中间件:

public class TimingMiddleware
{
    private readonly RequestDelegate _next;
    private readonly ILogger _logger;

    public TimingMiddleware(RequestDelegate next, ILogger logger)
    {
        _next = next;
        _logger = logger;
    }

    public async Task InvokeAsync(HttpContext context)
    {
        var watch = Stopwatch.StartNew();
        await _next(context);
        watch.Stop();

        _logger.LogInformation("请求 {Path} 耗时 {ElapsedMs}ms",
            context.Request.Path, watch.ElapsedMilliseconds);
    }
}

然后在 Program.cs 中注册并使用:

app.UseMiddleware();

如果需要传参(如开关、阈值),可加一个 Options 类配合构造函数注入。

中间件的执行顺序很关键

中间件按 UseXXX 的调用顺序加入管道,越靠前的越先执行「前置」,越靠后的越先执行「后置」。常见顺序建议:

Litero
Litero

AI co-writer for students

下载
  • 异常处理UseExceptionHandler)放最前,捕获后续所有异常
  • 静态文件UseStaticFiles)通常较早,避免走完整管道
  • 认证/授权UseAuthenticationUseAuthorization)放在路由之前
  • 终结点路由UseEndpointsMapControllers)放在最后,真正分发请求

顺序错了可能导致功能失效(比如把认证放路由后面,就根本不会校验)。

带参数的中间件写法(Options 模式)

比如想让 TimingMiddleware 只对特定路径计时,或设置慢请求告警阈值:

public class TimingOptions
{
    public string? PathPrefix { get; set; } = "/";
    public long WarnThresholdMs { get; set; } = 500;
}

修改中间件构造函数注入 IOptions,并在 InvokeAsync 中判断路径和耗时:

if (!context.Request.Path.StartsWithSegments(options.Value.PathPrefix))
    return await _next(context);

注册时可配置:

builder.Services.Configure(opt =>
{
    opt.PathPrefix = "/api/";
    opt.WarnThresholdMs = 200;
});
app.UseMiddleware();

基本上就这些。核心就三点:理解委托链、掌握类封装写法、盯紧注册顺序。不复杂但容易忽略细节。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

175

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

167

2025.12.18

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

201

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

187

2025.11.08

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

250

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

382

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

869

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1563

2024.08.16

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

27

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号