拦截器过滤器模式以及它们的联系和区别

目的:对应用程序的请求或响应做一些预处理/后处理

角色:

  • 过滤器接口:定义过滤器的方法
  • 具体过滤器:实现过滤器接口,包含具体的处理逻辑
  • 过滤器管理器:负责维护过滤器链和调用过滤器
  • 目标对象:请求处理的目的地,业务逻辑的实现,相当于被代理的方法或组件。
  • 客户端:发出请求的web浏览器或API客户端
    在这里插入图片描述
    场景:当要插入与业务无关的逻辑时,比如日志、鉴权等。

优点:

  • 职责分离:业务逻辑与通用操作分离
  • 可拓展性:可以灵活的添加、修改和删除过滤器
  • 复用性:过滤器可以在不同的请求中重用

缺点:影响性能,过滤链过长或过滤器执行的操作复杂,会影响性能。

过滤器和拦截器的区别

概念技术层次作用范围执行顺序依赖注入支持
过滤器Servlet 容器级别拦截所有请求,包括静态资源在请求进入 Servlet 容器时最先执行默认不支持
拦截器Spring MVC 框架级别,依赖 Spring 容器仅拦截控制器请求,不拦截静态资源在 DispatcherServlet 之后,Controller 方法执行前后执行支持

在这里插入图片描述
在这里插入图片描述

  • 定位:过滤器是 Servlet 容器级别的 “大门卫”,拦截器是 Spring MVC 框架级别的 “业务保安”
  • 范围:过滤器覆盖所有请求,拦截器只处理控制器请求
  • 依赖:过滤器不依赖 Spring,拦截器依赖 Spring
  • 选择原则:与容器相关用过滤器,与业务相关用拦截器

相关参考

https://www.runoob.com/design-pattern/intercepting-filter-pattern.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值