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

在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. 详细执行流程

text 复制代码
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. 关键区别

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

5. 使用场景

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

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

相关推荐
蒸蒸yyyyzwd4 小时前
cpp对象模型学习笔记1.1-2.8
java·笔记·学习
程序员徐师兄5 小时前
Windows JDK11 下载安装教程,适合新手
java·windows·jdk11 下载安装·jdk11 下载教程
RANCE_atttackkk5 小时前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
五岳6 小时前
DTS按业务场景批量迁移阿里云MySQL表实战(下):迁移管理平台设计与实现
java·应用·dts
zhougl9966 小时前
Java 所有关键字及规范分类
java·开发语言
Python 老手6 小时前
Python while 循环 极简核心讲解
java·python·算法
java1234_小锋7 小时前
Java高频面试题:MyISAM索引与InnoDB索引的区别?
java·开发语言
Mr_Xuhhh7 小时前
MySQL函数详解:日期、字符串、数学及其他常用函数
java·数据库·sql
测试开发Kevin8 小时前
小tip:换行符CRLF 和 LF 的区别以及二者在实际项目中的影响
java·开发语言·python
笨手笨脚の8 小时前
Redis: Thread limit exceeded replacing blocked worker
java·redis·forkjoin·thread limit