Spring中同一个Filter被连续调用两次

spring中使用过滤器filter做准入的控制,具体配置如下:( 注意!该注解写法是错误的!)

Spring中同一个Filter被连续调用两次_第1张图片

 

这里面注意SpringBoot中的注解的使用,其中@WebFilter将该class作为过滤器注册到Spring的容器中,@Order(1)作用是当存在同名过滤器时的使用先后顺序,@Component是将该class作为组件注册到Spring容器中。

如图所示,使用这种注解写法会导致在filter的chain中,出现了两次authFilter类,进而导致一次请求,连续调用两次AuthFilter类中的方法,影响效率。

Spring中同一个Filter被连续调用两次_第2张图片

 

同时,还会引起另一个问题,如果WebFilter注解配置的urlPatterns(例如:“/web/*)的话,因为同时配置了@Component,而在Component是没有配置urlPatterns的,这个Filter是被做了两次映射,分别映射到的URL是“/web/*”和”“/*”。这样就会导致所有的URL都会被该Filter处理。如图:

 

Spring中同一个Filter被连续调用两次_第3张图片

 

此时的chain是这样的:

 

Spring中同一个Filter被连续调用两次_第4张图片

此时因为@WebFilter配置了urlPatterns, 请求路径不匹配,所以不会加入chain中。但@Component没有配置,就会被映射到这个class中。

 

 

你可能感兴趣的:(Spring中同一个Filter被连续调用两次)