1.什么是过滤器?
过滤器 , 其实就是对客户端发出来的请求进行过滤。 浏览器发出, 然后服务器派servlet处理。 在中间就可以过滤, 其实过滤器起到的是拦截的作用。
2.作用:
- 对一些敏感词汇进行过滤
- 统一设置编码
- 自动登录
3.如何使用过滤器?
- 定义一个类, 实现Filter
public class FilterDemo implements Filter {
public void destroy() {
}
//如果想放行,那么在doFilter 方法里面操作,使用参数 chain
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
System.out.println("来到过滤器了。。。");
chain.doFilter(request, response); //放行,让请求到达下一个目标。
}
//init方法的参数 FilterConfig , 可以用于获取filter在注册的名字 以及初始化参数。
//其实这里的设计的初衷与ServletConfig是一样的。
public void init(FilterConfig fConfig) throws ServletException {
}
}
- 在web.xml里面注册过滤器,和注册Servlet基本一样
<filter>
<display-name>FilterDemo</display-name>
<filter-name>FilterDemo</filter-name>
<filter-class>com.itheima.filter.FilterDemo</filter-class>
</filter>
<filter-mapping>
<filter-name>FilterDemo</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
4.Filter的生命周期
- 创建:服务器启动时。
- 销毁:服务器停止时。
5.Filter执行顺序
- 客户端发出请求,先经过过滤器, 如果过滤器放行,那么才能到servlet
- 如果有多个过滤器, 那么他们会按照注册的映射顺序 来 排队。 只要有一个过滤器, 不放行,那么后面排队的过滤器以及咱们的servlet都不会收到请求。
6.针对 Dispatcher 设置
- REQUEST : 只要是请求过来,都拦截,默认就是REQUEST
- FORWARD : 只要是转发都拦截。
- ERROR : 页面出错发生跳转
- INCLUDE : 包含页面的时候就拦截。