当前位置: 首页 > news >正文

spring中的Interceptor使用说明


一、Interceptor 的核心概念

Interceptor(拦截器) 是 Spring MVC 提供的一种机制,用于在请求处理的不同阶段插入自定义逻辑。其核心作用包括:
• 预处理:在控制器方法执行前进行权限校验、日志记录等。

• 后处理:在控制器方法执行后修改响应数据或记录结果。

• 资源清理:在整个请求完成后释放资源或处理异常。

与 Filter 的区别:

特性Interceptor(拦截器)Filter(过滤器)
作用范围针对 Spring MVC 的控制器层作用于 Servlet 容器层面
依赖框架Spring MVC 管理Servlet 原生规范
数据访问可操作 ModelAndView仅能操作 HttpServletRequest/Response

在这里插入图片描述


二、Interceptor 的创建与配置

  1. 实现拦截器类
    继承 HandlerInterceptor 接口,重写以下方法:
public class AuthInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {// 请求前处理(如权限校验)return true; // 返回 false 中断请求}@Overridepublic void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) {// 控制器执行后、视图渲染前处理(如修改 Model 数据)}@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {// 请求完成后处理(如资源清理)}
}
  1. 注册拦截器
    通过 WebMvcConfigureraddInterceptors 方法配置:
@Configuration
public class WebConfig implements WebMvcConfigurer {@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(new AuthInterceptor()).addPathPatterns("/api/**")     // 拦截路径.excludePathPatterns("/login"); // 排除路径}
}

• 路径匹配规则:支持 Ant 风格(如 /user/* 匹配单层路径,/admin/** 匹配多级路径)。

• 多拦截器顺序:通过 Order 注解或实现 Ordered 接口控制优先级,值越小优先级越高。


三、拦截器的执行顺序

假设注册了 Interceptor1 和 Interceptor2:

  1. preHandle 方法:按注册顺序执行(Interceptor1 → Interceptor2)。
  2. postHandle 方法:按注册逆序执行(Interceptor2 → Interceptor1)。
  3. afterCompletion 方法:按注册逆序执行(Interceptor2 → Interceptor1)。

中断场景:若某一拦截器的 preHandle 返回 false,后续拦截器和控制器均不执行,但已通过 preHandle 的拦截器的 afterCompletion 仍会执行。


四、典型应用场景

  1. 权限校验
    preHandle 中检查用户登录状态或角色权限,拒绝非法请求。

    if (request.getSession().getAttribute("user") == null) {response.sendRedirect("/login");return false;
    }
    
  2. 日志记录
    记录请求路径、参数、耗时等信息:

    long startTime = System.currentTimeMillis();
    request.setAttribute("startTime", startTime);
    // 在 afterCompletion 中计算耗时
    
  3. 性能监控
    统计接口响应时间,优化慢请求。

  4. 数据预处理
    postHandle 中统一添加响应头或加密敏感数据。


五、注意事项与最佳实践

  1. 性能优化
    • 避免在拦截器中执行耗时操作(如远程调用)。

    • 合理设置拦截路径,减少不必要的拦截。

  2. 常见问题排查
    • 拦截器未生效:检查路径匹配规则、是否注册到 Spring 容器。

    • 顺序混乱:通过 @Order 明确优先级。

  3. 与 AOP 结合
    拦截器适用于请求生命周期中的横切逻辑,而 AOP 更适用于方法级别的切面(如事务管理)。


六、完整示例

  1. 日志拦截器
public class LogInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {System.out.println("请求开始: " + request.getRequestURI());return true;}@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {System.out.println("请求完成: " + request.getRequestURI());}
}
  1. 配置类
@Configuration
public class WebConfig implements WebMvcConfigurer {@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(new LogInterceptor()).addPathPatterns("/**");registry.addInterceptor(new AuthInterceptor()).addPathPatterns("/admin/**").order(1); // 高优先级}
}

总结

Spring Interceptor 是处理请求生命周期横切逻辑的利器,通过灵活配置路径和优先级,可实现权限控制、日志记录等通用功能。结合 preHandlepostHandleafterCompletion 的分阶段处理,能有效提升代码复用性和可维护性。

相关文章:

  • svn 提交后报错 : is scheduled for addtion,but is missing
  • aws平台s3存储桶夸域问题处理
  • JavaScript性能优化实战(14):跨端JavaScript性能优化
  • 从版本控制到协同开发:深度解析 Git、SVN 及现代工具链
  • 【Redis】二、Redis常用数据类型命令学习
  • 【STM32】自定义打印函数
  • SQL 多表关联与分组聚合:解密答题正确率分析
  • “零风险”探究,化学虚拟仿真实训​
  • 关于Vue自定义组件封装的属性/事件/插槽的透传问题
  • 一步步解析 HTTPS
  • 物联网之使用Vertx实现UDP最佳实践【响应式】
  • 【react18】在styled-components中引入图片报错
  • React深度解析:Hooks体系与Redux Toolkit现代状态管理实践
  • Spring Boot集成Spring AI与Milvus实现智能问答系统
  • 广州卓远VR受邀参加2025智能体育典型案例调研活动,并入驻国体华为运动健康联合实验室!
  • 【C/C++】探索单例模式:线程安全与性能优化
  • SQL数据处理流程
  • 微软正式发布 SQL Server 2025 公开预览版,深度集成AI功能
  • PostgreSQL日常维护
  • Flink SQL 计算实时指标同比的实现方法
  • 5网站建站/中国三大搜索引擎
  • 自己建网站做那个模块好/海外aso优化
  • 武汉网站搜索引擎优化/桔子seo工具
  • 网站怎么添加js广告位/淘宝店铺如何推广
  • 做竞价的网站可以做优化吗/google秒收录方法
  • 最具口碑的企业网站建设/搜索引擎营销方式