【出版社直供】servlet / jsp的软件
76.45元
包邮
(需用券)
去购买 >
为什么要用过滤器?
Servlet中的过滤器相当于守护后台资源的一道关卡,我们可以在过滤器中进行身份校验、权限认证、请求过滤等。
过滤器本身并不难,我们只需要知道他的定义方法、作用范围、执行顺序即可。
网上对于过滤器执行顺序的描述可能会让人产生误解。
图片来源于网络
客户端请求到达的时候,经过一次过滤器。
服务器处理完请求的时候,经过一次过滤器。
虽然经过两次过滤器,但不代表同样的代码执行了两次。
下面做了个简单的测试,看下执行结果就应该知道真正的执行流程了。
测试环境
tomcat9(servlet4.0)
jdk1.8
新版servlet可以通过注解注册servlet组件以及过滤器,无需再到web.xml下注册了。
测试过程
测试之间要先知道filterChain(过滤链)是干嘛的。
一个过滤器处理完后,会把request和response对象通过filterchain传递给下一个过滤器,如果没有下一个过滤器,则会直接开始执行业务代码,
单个过滤器
定义一个过滤器A
@WebFilter(value = "/*", filterName="A")public class FilterA implementsFilter {
@Overridepublic voiddoFilter(ServletRequest request, ServletResponse response, FilterChain chain)throwsIOException, ServletException {
SimpleDateFormat format= new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
System.out.println(format.format(newDate()));
System.out.println("A:拦截1");
chain.doFilter(request, response);
System.out.println(format.format(newDate()));
System.out.println("A:拦截2");
}
@Overridepublic void init(FilterConfig filterConfig) throwsServletException {
}
@Overr