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,其执行顺序与类名有关,按照类名的字典顺序执行

  • 10
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
本系统是应用于企业会议管理的系统,实现自动管理会议室,及准确得知会议室空闲、预定情况,规范公司会议管理,实现公司信息资源在各部门之间快速有效传递,避免资源的冲突。提高了会议室的使用率,节省会议组织者的间,妥善保管了会议记录。 学习目标 本系列讲座主要讲述如何利用Servlet3.0+mybatis+bootstrap+mysql构建企业级应用解决方案,主要分为三部分完成 第一部分:技能储备阶段,学习项目所需要的技能知识 第二部分:设计部分,通过需求分析,设计物理模型,画出原型界面(HTML) 第三部分:编码部分,具体实现各个功能模块 学完本系列课程后,学员将会达到以下学习目标: 本课程针对有一定程序开发基础并有志于JAVA WEB开发的学员,理解MVC开发模式,能够熟练使用PowerDesigner 设计数据库,熟练使用mybatis进行开发,熟悉Servlet3.0的一些新特性,掌握bootstrap基本用法 课程大纲 (一)会议管理系统之技能储备 第01课 项目简介、环境搭建 第02课 servlet3.0新特性之@WebServlet(登录示例) 第03课 servlet3.0新特性之@WebServlet_@WebInitParam详解 第04课 servlet3.0新特性之@WebFilter_@WebListener 第05课 JQuery AJAX 注册验证+二级菜单(JSON) 第06课 mybatis 框架搭建 第07课 mybatis 增删改查 第08课 mybatis 动态sql 第09课 bootstrap的搭建+栅格系统+table 第10课 bootstrap 表单 (二)会议管理系统之设计部分 第11课 原型设计_设备管理 第12课 原型设计_会议室管理+预约会议室 第13课 原型设计_会议管理+系统管理 第14课 数据库设计 第15课 框架搭建+html替换成jsp (二)会议管理系统之编码部分 第16课 用户登录 第17课 防止非法登录+个人信息显示 第18课 用信息添加+上传头像 第19课 用户信息管理(查询) 第20课 用户信息管理(修改) 第21课 删除用户+查看用户+权限变更 第22课 设备添加 第23课 设备管理(查询+修改) 第24课 设备管理(删除)+设备信息(多表联查) 第25课 查询设备信息(根据会议室条件查询) 第26课 添加会议室 第27课 会议管理(查询+修改) 第28课 会议室管理(修改+删除) 第29课 会议室查询(查看)+ajax验证会议室编号 第30课 会议室预约(1) 第31课 会议室预约(2) 第32课 会议室预约修改(查询) 第33课 会议室预约修改(1) 第34课 会议室预约修改(2) 第35课 会议室预约审核 第36课 预约审核(2)+预约查询(1) 第37课 预约查询(2) 第38课 预约查询(3)+权限设置 第39课 工作台

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值