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...");
}
}


浙公网安备 33010602011771号