所有controller interceptor_工作多年,很多人不知如何选择filter、interceptor、aspect

本文介绍了Filter、Interceptor和Aspect的区别,它们都是用于拦截处理请求的组件。Filter依赖于Servlet容器,适用于全局操作,如字符编码设置。Interceptor基于SpringMVC,用于AOP编程,能获取Controller对象但无法获取方法参数。Aspect则可以获取方法参数,适用于日志、事务等场景。执行顺序为:Filter -> Interceptor -> ControllerAdvice -> Aspect -> Controller。
摘要由CSDN通过智能技术生成

欢迎关注头条号:老顾聊技术

精品原创技术分享,知识的组装工


目录

  1. 前言
  2. Filter过滤器
  3. Interceptor拦截器
  4. Aspect切片
  5. 总结

前言

小伙伴们应该听说过过滤器、拦截器、切面,印象上都能够起到截断拦截的作用,在做一些业务需求时,不知道如何选择,今天老顾就来介绍一下他们之间的区别。

Filter过滤器

过滤器可以拦截到方法的请求和响应(ServletRequest request, ServletResponse response),并对请求响应做出过滤操作。

过滤器依赖于servlet容器。在实现上,基于函数回调,它可以对几乎所有请求进行过滤,一个过滤器实例只能在容器初始化时调用一次。

使用过滤器的目的是用来做一些过滤操作,获取我们想要获取的数据,比如:在过滤器中修改字符编码;在过滤器中修改HttpServletRequest的一些参数,包括:过滤低俗文字、危险字符等。

话不多说,先上代码

8f05bfc30fc0c8b3a9f1773b296346c9.png

再定义两个Controller,一个UserController,一个OrderController

51c558a35b2213f79c9303b10cafe4bf.png
4515a6be765172266e9ba2f45ff406f4.png

虽然Filter过滤器和Controller请求都已经定义了,但现在过滤器是不起作用的。需要把Filter配置一下,有两个方案

第一个方案在Filter上面加上@Component

@Componentpublic class TimeFilter implements Filter

第二个方案配置化注册过滤器

3d8c373731fa3e304afe9ad410c39572.png

第二个方案的特点就是可以细化到过滤哪些规则的URL

我们来启动应用时,过滤器被初始化了,init函数被回调

d428bb55a1217052d12b7bd7acd0e70c.png

请求http://localhost:9000/order/1

052cb11c38b62b4bbe2e8ee97241e9f0.png

看看控制台的日志输出

e5f8429ddb2718e3f5c3b9cd3ab364ee.png

请求http://localhost:9000/user/1

338a00f0522f12f8f842bab1a2757474.png

控制台日志输出

dbd8f90efb496166933d464cf29f5fc8.png

停止应用后,控制台输出

ea675de4e756d6640b38b0966a04a260.png

Filter随web应用的启动而启动,只初始化一次,随web应用的停止而销毁。

1.启动服务器时加载过滤器的实例,并调用init()方法来初始化实例;

2.每一次请求时都只调用方法doFilter()进行处理

3.停止服务器时调用destroy()方法,销毁实例。

我们再来看看doFilter方法

doFilter(ServletRequest request, ServletResponse response, FilterChain chain)

从参数我们看到,filter里面是能够获取到请求的参数和响应的数据;但此方法是无法知道是哪一个Controller类中的哪个方法被执行。

还有一点需要注意的是,filter中是没法使用注入的bean的,也就是无法使用@Autowired

f01f8de06abdec8adef711b9b5b06f84.png

上面代码注入的值为null。这是为什么呢

其实Spring中,web应用启动的顺序是:listener->filter->servlet,先初始化listener,然后再来就filter的初始化,再接着才到我们的dispathServlet的初始化,因此,当我们需要在filter里注入一个注解的bean时,就会注入失败,因为filter初始化时,注解的bean还没初始化,没法注入。

如果一定你要使用,需要做一些处理,可以私信老顾哦

Interceptor拦截器

依赖于web框架,在SpringMVC中就是依赖于SpringMVC框架。在实现上,基于Java的反射机制,属于面向切面编程(AOP)的一种运用,就是在一个方法前,调用一个方法,或者在方法后,调用一个方法。

f2534a9de4912f11457099bb35c84c29.png

在WebMvcConfigurationSupport配置一下

e9965539691965088eb401f2e1b301a0.png

执行结果

74bc153bfb9677c9a63eed6f95e55604.png

我们发现拦截器中可以获取到Controller对象

preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)

object handler就是controller方法对象

HandlerMethod handlerMethod = (HandlerMethod)handler;handlerMethod.getBean().getClass().getName(); //获取类名handlerMethod.getMethod().getName(); //获取方法名

但我们发现获取不到方法的参数值,这个是为什么呢?在DispatcherServlet类中,方法

doDispatch(HttpServletRequest request, HttpServletResponse response)

74a83ea154a97cd007afbac1655dd2ec.png

applyPreHandle这个方法执行,就是执行的拦截器的preHandler方法,但这个过程中,controller方法没有从request中获取请求参数,组装方法参数;而是在ha.handle这个方法的时候,才会组装参数

虽然没法得到方法的参数,但是可以获得IOC的bean哦。

再说明一点的是postHandler方法

postHandler方法的执行,当controller内部有异常,posthandler方法是不会执行的。

afterCompletion方法,不管controller内部是否有异常,都会执行此方法;此方法还会有个Exception ex这个参数;如果有异常,ex会有异常值;没有异常 此值为null

注意点如果controller内部有异常,但异常被@ControllerAdvice 异常统一捕获的话,ex也会为null

Aspect切片

AOP操作可以对操作进行横向的拦截,最大的优势在于他可以获取执行方法的参数,对方法进行统一的处理。常见使用日志,事务,请求参数安全验证

d49254f1f78edbc2cc0f2d2079a1a9b7.png

上面的代码中,我们是可以获取方法的参数的

8d69b3aa670bebd46e161538da452e0d.png

虽然切面aop可以拿到方法参数,但拿不到response,request对象。

总结

我们这里来总结一下过滤器、拦截器、Aspect,看看区别

c2c0d889856e5831da663681be6be221.png

如果三者方式同时采用,那他们的执行顺序是什么呢?

filter -> interceptor -> ControllerAdvice -> aspect -> controller

返回值顺序,或异常返回顺序

controller -> aspect -> controllerAdvice -> Interceptor -> Filter

40a1be75a9d7cd7c04d552cddfc17fce.png

用一个图描述一下执行顺序

bb95a76fd3d4f28e85aef305669b5b2d.png

小伙伴们可以根据自身业务,和上面技术的各自特点,去选择相应的技术。今天老顾就介绍到这里,谢谢!!!


---End---

最近老顾上传了微服务网关的分享课程,请大家多多支持

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值