1、过滤器定义:
过滤器是服务端组件,它可以截取客户端的请求与响应信息,并对这些信息进行过滤;
2、过滤器的工作原理:
3、过滤器的生命周期:
实例化:web容器启动时,通过加载web.xml配置文件,对过滤器进行实例化,只会实例化一次;
初始化:实例化之后会调用过滤器的init()方法进行初始化,初始化同样只有一次;方法可以读取web.xml中的参数;
过滤:过滤器的doFilter()方法,每次请求都会执行;
销毁:web容器关闭时会执行过滤器的销毁方法destroy();
4、过滤器的创建及配置:
创建过滤器需要实现Filter接口
package com.imooc.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 FirstFilter implements Filter {
@Override
public void destroy() {
// TODO Auto-generated method stub
}
@Override
public void doFilter(ServletRequest arg0, ServletResponse arg1,
FilterChain arg2) throws IOException, ServletException {
// TODO Auto-generated method stub
}
@Override
public void init(FilterConfig arg0) throws ServletException {
// TODO Auto-generated method stub
}
}
web.xml中配置过滤器
<filter>
<filter-name>FirstFilter</filter-name>
<filter-class>com.imooc.filter.FirstFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>FirstFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
5、过滤器链
6、过滤器链执行顺序
7、过滤器分类:
REQUEST
INCLUDE
ERROR
FORWARD
8、基于注解的过滤器配置
@WebFilter(filterName="FirstFilter",value={"/*"},dispatcherTypes={DispatcherType.FORWARD,DispatcherType.ASYNC})
public class FirstFilter implements Filter{}
9、过滤器应用场景