博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java-过滤器Filter_多个Filter的执行顺序
阅读量:5061 次
发布时间:2019-06-12

本文共 3393 字,大约阅读时间需要 11 分钟。

【Filter链】

*在一个web应用中,可以开发编写多个Filter,这些Filter组合起来称为一个Filter链。

*web服务器根据Filter在web.xml中的注册顺序,决定先调用哪个Filter,当第一个Filter的doFilter方法被调用时,web服务器会创建一个代表Filter链的FilterChain对象传递给该方法,在doFilter方法中,开发人员如果调用了FilterChain对象的doFilter方法,则web服务器会检查FilterChain对象中是否还有filter,如果有,则调用第二个filter,如果没有,则调用目标资源。

 

【工程截图】

设计了两个Filter和一个Servlet,访问Servlet时,查看Filter的执行顺序。

【web.xml】

FilterDemo01
index.jsp
FilterTest01
com.Higgin.web.filter.FilterTest01
FilterTest01
/*
FilterTest02
com.Higgin.web.filter.FilterTest02
FilterTest02
/*

 

【FilterTest01.java】

package com.Higgin.web.filter;import java.io.IOException;import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; public class FilterTest01 implements Filter{ @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { System.out.println("FilterTest01 执行前---"); chain.doFilter(request, response);//让目标资源执行,即:放行 System.out.println("FilterTest01 执行后---"); } @Override public void init(FilterConfig arg0) throws ServletException { } @Override public void destroy() { } }

【FilterTest02.java】

package com.Higgin.web.filter;import java.io.IOException;import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; public class FilterTest02 implements Filter{ @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { System.out.println("FilterTest02 执行前---"); chain.doFilter(request, response); //放行 System.out.println("FilterTest02 执行后---"); } @Override public void init(FilterConfig arg0) throws ServletException { } @Override public void destroy() { } }

 

【ServletTest01.java】

package com.Higgin.web.servlet;import java.io.IOException;import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * Servlet implementation class ServletTest01 */ @WebServlet("/ServletTest01") public class ServletTest01 extends HttpServlet { private static final long serialVersionUID = 1L; public ServletTest01() { super(); } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //response.getWriter().write("中国 加油!China Come on!"); System.out.println("执行ServletTest01---"); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request,response); } }

【运行结果】

在浏览器中输入:http://localhost:8080/FilterDemo01/ServletTest01

查看控制台输出结果

 

自己可以尝试分别注释FilterTest01和FilterTest02中的chain.doFilter方法,用Junit查看具体的执行过程。

转载于:https://www.cnblogs.com/hfultrastrong/p/7239513.html

你可能感兴趣的文章
多服务器操作利器 - Polysh
查看>>
[LeetCode] Candy
查看>>
Jmeter学习系列----3 配置元件之计数器
查看>>
jQuery 自定义函数
查看>>
jq 杂
查看>>
jquery datagrid 后台获取datatable处理成正确的json字符串
查看>>
作业一
查看>>
AJAX
查看>>
ActiveMQ与spring整合
查看>>
web服务器
查看>>
js数组操作大全
查看>>
创业者要处理好的10大关系
查看>>
佛教和道教对“妖”的差异
查看>>
[TimLinux] Python IDE工具
查看>>
[TimLinux] Python Django与WSGI的简介
查看>>
从其它系统登录到SharePoint 2010系统的单点登录
查看>>
ElMAH(ASP.NET错误日志记录与通知)系列文章-基础应用篇
查看>>
pexpect学习阶段
查看>>
做最多的,展示最好的
查看>>
会员未登录显示ID=1的会员信息 解决方案
查看>>