Servlet 3.0+ 使用@WebFilter注解注册Filter过滤器时的顺序问题

Servlet 3.0+ 使用@WebFilter注解注册Filter过滤器时的顺序问题

1.问题描述

最近自己在折腾一个小框架,查资料的时候发现Servlet 3.0+已经支持了注解配置,也就是说可以扔掉web.xml了(可怜我用的是Servlet 4,才发现有这么个东西,没错,我落伍了)赶紧拿来尝尝鲜,不过在配置的过程中发现一个问题:
在web.xml中Filter的顺序是自上而下的,如果换成了注解@WebFilter,那么Filter的加载顺序和执行顺序应该如何定义

2.开始折腾

先上示例(不想看过程的可以直接看最底部的结论):
新建工程,写了三个Filter,使用@WebFilter注解
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

好了,启动看看效果
在这里插入图片描述
WTF?
再请求一下试试:
在这里插入图片描述
emmmm…是我打开方式不对吗?
不断折腾之后,发现结果顺序不变,那就得寻找规律了。。。。。。
废话不多说,开始打断点调试(中间费时的过程不啰嗦,直接上干货):
在这里插入图片描述
(请无视那个Tomcat XXXX 的Filter,那个是Tomcat本身的Filter)
经过断点追踪发现,tomcat启动时Filter初始化,会把所有的Filter加载到一个HashMap里,那么。。。。。。
在这里插入图片描述
运行结果:在这里插入图片描述
再换数据测试一遍:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
对上了,那么结论来了:
通过@WebFilter注解注册的Filter类,初始化之前是通过HashMap存储,其key 值对应注解 filterName 的值,即初始化顺序与@WebFilter注解的filterName值的hash值有关。

再说请求顺序,还记得一开始的时候我们试了一下,发现初始化顺序好像和请求时的顺序不一样,那我们再来自己研究一下:
在这里插入图片描述
(中间试了很多乱七八糟的东西,一样,直接上干货):
修改类名之后发现了不一样的东西:
在这里插入图片描述

FilterTestA > CFilterTestA
FilterTestB > AFilterTestB
FilterTestC > BFilterTestC
模拟请求一次,执行结果:
在这里插入图片描述
再换换试试:
在这里插入图片描述

FilterTestA > T2FilterTestA
FilterTestB > T3FilterTestB
FilterTestC > T1FilterTestC
在这里插入图片描述
很明显:
通过@WebFilter注解注册的Filter类,其加载熟顺序与类名有关,即Filter类名的字段排序。

3.问题结论

(1)通过@WebFilter注解注册的Filter,其加载顺序与执行顺序无关
(2)通过@WebFilter注解注册的Filter,其加载顺序与注解的filterName值相关(底层通过HashMap存储,key值即filterName值)
(3)通过@WebFilter注解注册的Filter,其执行顺序与类名有关,按照类名的字典顺序执行

  • 11
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值