其他分享
首页 > 其他分享> > Filter细节web.xml配置方式以及执行流程和生命周期

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