首页 > 其他分享 >中间件 vs 过滤器

中间件 vs 过滤器

时间:2024-12-25 20:20:33浏览次数:4  
标签:请求 中间件 vs MVC 过滤器 操作 执行

在 ASP.NET Core 中,中间件(Middleware)过滤器(Filters) 是两种不同的机制,用于处理请求和响应的管道。它们的作用和适用场景有所不同,以下是它们的对比和详细说明:


中间件(Middleware)

定义

中间件是 ASP.NET Core 请求处理管道中的组件,用于处理 HTTP 请求和响应。每个中间件可以对请求进行处理,并决定是否将请求传递给下一个中间件。

特点

  1. 全局性:中间件作用于整个应用程序的请求管道,适用于所有请求。
  2. 顺序性:中间件的执行顺序由 UseMiddlewareUse 方法的调用顺序决定。
  3. 灵活性:可以处理请求和响应,甚至可以终止请求管道(不调用下一个中间件)。
  4. 低级别:中间件更接近底层,可以直接操作 HttpContext

适用场景

  • 全局的请求处理逻辑(如身份验证、日志记录、异常处理)。
  • 修改请求或响应的内容(如添加自定义头、压缩响应)。
  • 终止请求管道(如未授权的请求直接返回 401)。

示例

public class CustomMiddleware
{
    private readonly RequestDelegate _next;

    public CustomMiddleware(RequestDelegate next)
    {
        _next = next;
    }

    public async Task InvokeAsync(HttpContext context)
    {
        // 处理请求
        context.Response.Headers.Add("X-Custom-Header", "Middleware");

        // 调用下一个中间件
        await _next(context);
    }
}

// 注册中间件
app.UseMiddleware<CustomMiddleware>();

过滤器(Filters)

定义

过滤器是 ASP.NET Core MVC 或 Minimal API 中的一种机制,用于在特定的 MVC 操作(Action)或控制器(Controller)前后执行逻辑。过滤器是 MVC 框架的一部分,而不是请求管道的一部分。

特点

  1. 局部性:过滤器可以应用于特定的控制器或操作,而不是全局的。
  2. 细粒度控制:可以在操作执行前、执行后或执行过程中插入逻辑。
  3. MVC 集成:过滤器与 MVC 框架紧密集成,可以访问 MVC 特定的上下文(如 ActionExecutingContext)。
  4. 高级别:过滤器更关注 MVC 操作的行为,而不是底层的 HTTP 请求。

适用场景

  • 控制器或操作级别的逻辑(如授权、模型验证、日志记录)。
  • 修改操作的结果(如格式化响应、处理异常)。
  • 在操作执行前后执行特定逻辑。

过滤器类型

  1. Authorization Filters:用于授权(如 [Authorize])。
  2. Resource Filters:在操作执行前后执行逻辑(如缓存)。
  3. Action Filters:在操作执行前后执行逻辑(如日志记录)。
  4. Exception Filters:处理操作中的异常。
  5. Result Filters:在操作结果执行前后执行逻辑(如格式化响应)。

示例

public class CustomActionFilter : IActionFilter
{
    public void OnActionExecuting(ActionExecutingContext context)
    {
        // 在操作执行前执行
        context.HttpContext.Response.Headers.Add("X-Custom-Header", "ActionFilter");
    }

    public void OnActionExecuted(ActionExecutedContext context)
    {
        // 在操作执行后执行
    }
}

// 注册过滤器
[ServiceFilter(typeof(CustomActionFilter))]
public class HomeController : Controller
{
    public IActionResult Index()
    {
        return View();
    }
}

中间件 vs 过滤器的对比

特性 中间件(Middleware) 过滤器(Filters)
作用范围 全局(整个应用程序的请求管道) 局部(特定的控制器或操作)
执行顺序 在请求管道的早期执行 在 MVC 操作执行前后执行
适用场景 全局的请求处理逻辑(如日志、异常处理) 控制器或操作级别的逻辑(如授权、模型验证)
访问上下文 直接访问 HttpContext 访问 MVC 特定的上下文(如 ActionContext
灵活性 更灵活,可以终止请求管道 更专注于 MVC 操作的行为
性能 更轻量,适合底层操作 稍重,适合 MVC 特定的逻辑

如何选择?

  1. 使用中间件
    • 当你需要处理全局的请求逻辑时。
    • 当你需要直接操作 HttpContext 时。
    • 当你需要在 MVC 框架之外处理请求时。
  2. 使用过滤器
    • 当你需要处理特定控制器或操作的逻辑时。
    • 当你需要与 MVC 框架紧密集成时(如授权、模型验证)。
    • 当你需要在操作执行前后执行特定逻辑时。

结合使用

在实际项目中,中间件和过滤器可以结合使用。例如:

  • 使用中间件处理全局的日志记录和异常处理。
  • 使用过滤器处理控制器或操作级别的授权和模型验证。

通过合理使用中间件和过滤器,可以构建一个高效、灵活且易于维护的 ASP.NET Core 应用程序。

标签:请求,中间件,vs,MVC,过滤器,操作,执行
From: https://www.cnblogs.com/liyongqiang-cc/p/18631327

相关文章

  • VScode中配置ESlint+Prettier详细步骤(图文详情)
    VScode中配置ESlint+Prettier详细步骤(图文详情)前置环境:node18.19.0vite3.2.11vue3.2.47本文将不在演示vue3基础工程创建,如果还没有vue3项目工程请参考文章:Vite创建Vue3工程并引入ElementPlus(图文详细)本文的ESlint+Prettier版本:ESlint8.57.1Prettier3.2.51ed......
  • 32. 过滤器和拦截器有什么区别
    1.实现原理不同过滤器和拦截器底层实现不同。过滤器是基于函数回调的,一般自定义的过滤器中都会实现一个doFilter()方法,这个方法有一个FilterChain参数,而实际上它是一个回调接口。拦截器是基于Java的反射机制(动态代理)实现的。2.触发时机不同过滤器Filter是在请求进入容器......
  • 过滤器、监听器和拦截器
    1.过滤器、监听器和拦截器过滤器:在servlet中,过滤器也就是Filter,它主要用于过滤字符编码,做一些统一的业务等等。是使用javax.servlet.Filter接口进行实现的。在代码安全中,他常被用于防止XSS,防SQL注入,防任意文件上传等。在配置了Filter之后,它可以统一过滤危险字符,省时省力。......
  • Kong vs Nginx全面对比与实战示例:从API网关到配置管理的深入解析
    言简意赅的讲解Kong解决的痛点在微服务和API网关盛行的时代,对HTTP请求的路由、负载均衡、代理和服务发现的需求愈加明显。Nginx作为高性能HTTP服务器和反向代理服务器已久负盛名,而Kong则是基于Nginx(和OpenResty)构建的API网关解决方案,通过插件系统和AdminAPI为开发者提供了......
  • js压缩代码还原的vscode插件
    1.Prettier-Codeformatter:Prettier是一个非常流行的代码格式化工具,支持多种语言,包括JavaScript。它可以按照预设的规则自动格式化你的代码。对于压缩的代码,它能够很好地展开并格式化。2.Beautify:Beautify插件专为美化HTML,CSS,和JavaScript代码而设计。你可......
  • vscode怎么连接远程服务器使用jupyter和pycharm?安装了jupyter插件为什么还是打不开jup
    本文主要从下面三个方面进行1.vscode的优势2.怎么安装并配置vscode3.怎么使用jupyter和pycharm4.我遇到的问题(已解决)(1)显示你即将连接到不受visualstudiocode版本(2)解决安装了jupyter插件但是还是打不开.ipynb文件无法打开笔记本编辑器类型为"jupyter-notebook"的资源......
  • VSCode配置启动Vue项目
    VSCode配置启动Vue项目|Id|Title|DateAdded|SourceUrl|PostType|Body|BlogId|Description|DateUpdated|IsMarkdown|EntryName|CreatedTime|IsActive|AutoDesc|AccessPermission||-------------|-------------|-------------|-------------|--......
  • 定制最小linux系统 - 4: 使用vscode单步调试
    内核毕竟是一个很大的工程,有时看得一头雾水,如果能单步调试的话,对于理解可能有亿点帮助.下面一步步搭建qemu+vscode环境对内核进行单步调试.第一步编译内核定制最小linux系统-1:编译linux内核-CSDN博客https://blog.csdn.net/weixin_46766770/article/details/1......
  • 关于VS Code崩溃提示‘-1247483645‘的解决方案 - 随笔记录
    今天开机运行VSCode时偶然发现它总是无法正常运行,提示框中报错的内容有这么一条:thewindowterminatedunexpectedly(reason:'crashed',code:'-1247483645')上网查找并尝试了很多网友的解决方案,彻底删除后重装或是使用网页版取代等等,但都不能很好地解决这个问题,最后测试为VSC......
  • 使用 VS Code 调试
    使用VSCode调试您的程序,您需要让VSCode监听主进程<code(mainprocess)和渲染器进程(rendererprocess)。下面为您提供了一个简单的配置文件。请在根目录新建一个.vscode文件夹,然后在其中新建一个launch.json配置文件并填写如下内容。{"version":"0.2.0","......