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

在Spring Boot实战中碰到的拦截器与过滤器是什么?

在Spring Boot实战中,拦截器(Interceptors)和过滤器(Filters)是两个常用的概念,它们用于在应用程序中实现一些通用的逻辑,如日志记录、权限验证、请求参数处理等。虽然它们都可以用于对请求进行处理,但在实现和使用上有一些不同之处。

过滤器(Filters)

过滤器是Servlet规范中定义的一种组件,用于拦截HTTP请求和响应。在Spring Boot应用中,你可以使用过滤器来实现对HTTP请求和响应的处理,无需依赖Spring框架。

作用:

  • 过滤器可以在请求到达目标资源之前进行预处理,也可以在响应返回给客户端之前进行后处理。
  • 主要用于对请求进行过滤、转换和修改,如添加请求头、修改请求参数、验证用户权限等。
  • 可以对请求进行统一的日志记录、字符编码处理等。

实现:

  • 实现javax.servlet.Filter接口或者继承javax.servlet.Filter类,并实现其doFilter方法来处理请求。
  • 在Spring Boot应用中,可以通过注解@WebFilter或者在配置类中注册Filter来注册过滤器,使其生效。

示例:

@Component
public class LoggingFilter implements Filter {@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {// 在请求到达目标资源之前进行预处理HttpServletRequest httpRequest = (HttpServletRequest) request;System.out.println("Request URI: " + httpRequest.getRequestURI());// 执行下一个过滤器(如果有),或者调用目标资源chain.doFilter(request, response);// 在响应返回给客户端之前进行后处理System.out.println("Response Status: " + HttpServletResponse.SC_OK);}
}

拦截器(Interceptors)

拦截器是Spring框架提供的一种机制,用于在请求处理的各个阶段进行拦截和处理。与过滤器不同,拦截器是Spring MVC框架中的一部分,可以访问Spring MVC的上下文和功能。

作用:

  • 拦截器主要用于在请求处理的不同阶段执行一些通用逻辑,如权限验证、用户登录检查、国际化处理等。
  • 可以在请求处理前、请求处理后以及请求完成后执行一些操作。

实现:

  • 实现org.springframework.web.servlet.HandlerInterceptor接口,并实现其preHandle、postHandle和afterCompletion方法来处理请求。
  • 在Spring Boot应用中,通过配置类注册拦截器,并指定拦截的URL路径或者拦截的Controller类来启用拦截器。

示例:

@Component
public class AuthorizationInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)throws Exception {// 在请求处理前执行权限验证逻辑if (!checkAuthorization(request)) {response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);return false;}return true;}@Overridepublic void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,ModelAndView modelAndView) throws Exception {// 在请求处理后执行操作}@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler,Exception ex) throws Exception {// 在请求完成后执行操作}private boolean checkAuthorization(HttpServletRequest request) {// 进行权限验证逻辑return true;}
}

区别与选择

在选择使用过滤器还是拦截器时,需要考虑以下几点:

  1. 功能需求:如果需要对请求进行全局的过滤、转换或修改,通常选择过滤器;如果需要在Spring MVC框架中实现一些通用的逻辑,如权限验证、日志记录等,通常选择拦截器。

  2. 使用范围:过滤器是Servlet规范中定义的,可以在任何Servlet容器中使用;而拦截器是Spring MVC框架提供的,只能在Spring MVC应用中使用。

  3. 访问上下文:过滤器无法访问Spring的上下文和功能,只能对HTTP请求进行处理;拦截器可以访问Spring MVC的上下文和功能,如控制器、模型等。

  4. 统一性:过滤器对所有请求都生效,而拦截器可以根据条件选择是否拦截某个请求。

综上所述,过滤器和拦截器在Spring Boot应用中都有各自的作用和用法,根据具体的需求和场景选择合适的方式来实现对请求的处理。

黑马程序员免费预约咨询

http://www.lryc.cn/news/339568.html

相关文章:

  • 数据可视化基础与应用-04-seaborn库人口普查分析--如何做人口年龄层结构金字塔
  • 软考之【系统架构设计师】
  • LigaAI x 极狐GitLab,共探 AI 时代研发提效新范式
  • 如何看待2023年图灵奖
  • 《云原生安全攻防》-- 云原生攻防矩阵
  • 自然语言处理: 第二十七章LLM训练超参数
  • Linux使用C语言实现Socket编程
  • Swin Transformer——披着CNN外皮的transformer,解决多尺度序列长问题
  • 数据结构排序算法
  • 【深度剖析】曾经让人无法理解的事件循环,前端学习路线
  • Spring 事务失效总结
  • K8S节点kubectl命令报错x509: certificate signed by unknown authority
  • 【HTML】制作一个简单的实时字体时钟
  • servlet的三个重要的类(httpServlet 、httpServletRequst、 httpServletResponse)
  • 【软考】设计模式之命令模式
  • 波奇学Linux:ip协议
  • Efficient Multimodal learning from data-centric perspective
  • ubuntu下交叉编译ffmpeg到目标架构为aarch架构的系统
  • 【Linux C | 多线程编程】线程同步 | 条件变量(万字详解)
  • 【高阶数据结构】哈希表 {哈希函数和哈希冲突;哈希冲突的解决方案:开放地址法,拉链法;红黑树结构 VS 哈希结构}
  • 嵌入式之计算机网络篇(七)
  • C++|运算符重载(1)|为什么要进行运算符重载
  • 【ARM 裸机】汇编 led 驱动之烧写 bin 文件
  • 计算机网络之CIDR
  • 【无标题】系统思考—智慧共赢座谈会
  • 【Linux C | 多线程编程】线程同步 | 互斥量(互斥锁)介绍和使用
  • mid_360建图和定位
  • ThreadX在STM32上的移植:通用启动文件tx_initialize_low_level.s
  • 【python实战】游戏开发——恐龙跳跃小游戏
  • 成都百洲文化传媒有限公司电商领域的新锐力量