Filter细节web.xml配置方式以及执行流程和生命周期
作者:互联网
Filter细节web.xml配置方式
<filter> <filter-name>filedemo1</filter-name> <filter-class>com.tomcat1.web.filter.FilterDemo1</filter-class> </filter> <filter-mapping> <filter-name>filedemo1</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
过滤器的执行流程
@WebFilter("/*") public class FilterDemo2 implements Filter { public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException { //对request对象请求消息增强 System.out.println("filterDemo2执行了..."); //放行 chain.doFilter(req, resp); //对response对象的响应消息增强 System.out.println("filterDemo2返回..."); } public void init(FilterConfig config) throws ServletException { } public void destroy() { } }
从运行结果可以看出,先执行过滤器,执行放行之后的资源,再返回执行过滤器放行之后的代码
过滤器的生命周期
doFilter:每一次请求被拦截资源时,会执行,执行多次
init:在服务器启动后,创建Filter对象,然后调用init方法,只执行一次,用于加载资源
destroy:在服务器关闭后,Filter对象被销毁,如果服务器是正常关闭,则会执行destroy方法,只执行一次,用于释放资源
@WebFilter("/*") public class FilterDemo3 implements Filter { /** * 每一次请求被拦截资源时,会执行,执行多次 * @param req * @param resp * @param chain * @throws ServletException * @throws IOException */ public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException { System.out.println("dofilter..."); //放行 chain.doFilter(req, resp); } /** * 在服务器启动后,创建Filter对象,然后调用init方法,只执行一次,用于加载资源 * @param config * @throws ServletException */ public void init(FilterConfig config) throws ServletException { System.out.println("init..."); } /** * 在服务器关闭后,Filter对象被销毁,如果服务器是正常关闭,则会执行destroy方法,只执行一次,用于释放资源 */ public void destroy() { System.out.println("destroy..."); } }
标签:xml,web,ServletException,throws,Filter,init,执行,public 来源: https://www.cnblogs.com/xjw12345/p/16598015.html