再论Spring MVC中Filter和HandlerInterceptor的优先级

news/2025/2/25 17:58:12

在Spring MVC中,Filter和HandlerInterceptor的执行顺序及优先级如下:


1. 执行顺序与优先级

  • Filter(Servlet规范)的优先级高于 HandlerInterceptor(Spring MVC框架)。

  • 请求处理流程

    1. Filter链:所有配置的Filter按顺序处理请求(在请求进入DispatcherServlet之前)。
    2. DispatcherServlet:请求到达Spring MVC核心控制器。
    3. HandlerInterceptor:通过preHandle方法介入请求(在Controller方法调用前)。
  • 响应处理流程

    1. HandlerInterceptorpostHandle(Controller执行后,视图渲染前)和afterCompletion(请求完全结束后)。
    2. Filter链:按逆序处理响应(从最后一个Filter回到第一个)。

2. 详细执行流程

HTTP请求
    → Filter1 → Filter2 → ... → FilterN
    → DispatcherServlet
        → HandlerInterceptor1.preHandle()
        → HandlerInterceptor2.preHandle()
        → Controller方法
        → HandlerInterceptor2.postHandle()
        → HandlerInterceptor1.postHandle()
        → 视图渲染(如存在)
        → HandlerInterceptor2.afterCompletion()
        → HandlerInterceptor1.afterCompletion()
    ← FilterN处理响应(逆序) ← ... ← Filter1处理响应

3. 配置顺序的影响

  • Filter顺序
    • web.xml中按配置顺序执行(或通过FilterRegistrationBeanorder属性)。
  • HandlerInterceptor顺序
    • 通过InterceptorRegistry添加的顺序决定:
      • preHandle:按注册顺序执行。
      • postHandleafterCompletion:按注册逆序执行。

4. 关键区别

特性FilterHandlerInterceptor
规范/框架Servlet规范Spring MVC框架
作用范围所有请求(包括静态资源)Spring管理的Controller请求
访问Spring上下文无法直接访问可以直接访问Spring Bean
控制粒度更底层(请求/响应预处理)更贴近业务逻辑(如Controller前后处理)

5. 使用场景

  • Filter:处理与业务无关的通用逻辑(如编码设置、日志记录、跨域处理)。
  • HandlerInterceptor:处理与业务相关的逻辑(如权限校验、参数预处理)。

通过理解两者的优先级和执行顺序,可以更灵活地设计请求处理逻辑。


http://www.niftyadmin.cn/n/5865798.html

相关文章

从0-1学习Mysql第三章: 数据类型

第三章:数据类型 在本章中,我们将学习 MySQL 中的常用数据类型,以及如何根据不同的需求选择合适的数据类型。同时,我们也会讲解 NULL 值和默认值的使用方式,以及一些常见的错误示例和面试题。通过本章的学习&#xff…

设计模式-(单例,简单工厂,工厂,抽象工厂)

单例模式 概念: 确保一个类只有一个实例,而且自行实例化并向震哥哥系统提供这个实例 应用: 无状态的,一般以工具类形式,进行提供 代码: 懒汉式,双重检查锁 class Singleton {private sta…

FutureTask 和 CompletableFuture

FutureTask 和 CompletableFuture 是 Java 并发编程中用于处理异步任务的两种工具,但它们在功能和使用场景上有显著区别。以下是两者的主要对比: 1. FutureTask 定义:FutureTask 是 Future 接口的一个实现类,表示一个异步计算任务…

java23种设计模式-建造者模式

建造者模式(Builder Pattern)学习笔记 1. 模式定义 建造者模式是一种创建型设计模式,通过分步构建复杂对象的方式,将对象的构建过程与表示分离。允许使用相同的构建过程创建不同的对象表示。 2. 适用场景 ✅ 需要创建包含多个…

2025年信息科学与工程学院科协机器学习介绍——机器学习基本模型介绍

机器学习 目录 机器学习一.安装基本环境conda/miniconda环境 二.数据操作数据预处理一维数组二维数组以及多维数组的认识访问元素的方法torch中tenson的应用张量的运算张量的广播 三.线性代数相关知识四.线性回归SoftMax回归问题(分类问题)什么是分类问题…

利用python和gpt写一个conda环境可视化管理工具

最近在学习python,由于不同的版本之间的差距较大,如果是用环境变量来配置python的话,会需要来回改,于是请教得知可以用conda来管理,但是conda在管理的时候老是要输入命令,感觉也很烦,于是让gpt帮…

C++ 继承与运算符重载的简单练习

1.长方形的继承类 #include <iostream> #include <cstring> #include <cstdlib> #include <unistd.h> #include <sstream> #include <vector> #include <memory>using namespace std; class AB{ private:int a;int …

【odoo18-文件管理】在uniapp上访问odoo系统上的图片

在uniapp上访问odoo系统上的图片 1、以url的形式访问 a&#xff1a;以odoo本身的域名&#xff0c;比如http://127.0.0.1:8069/web/image/product.template/3/image_128?unique1740380422000&#xff0c;这种方式需要解决跨域的问题。 b&#xff1a;以文件服务器的形式&…