过滤器Filter是什么?
过滤器 , 其实就是对客户端发出来的请求进行过滤。 浏览器和服务器的servlet中间又加了一层。 过滤器起到的是拦截的作用,还可能出现增加代码(字符格式),它本身也可以写代码只要是针对多个servlet的。filter是双向的,但服务器到浏览器一般不需要过滤。
如何使用
- 定义一个类, 实现Filter
public class FilterDemo implements Filter {
public void destroy() {
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { //我们一般使用这个函数
System.out.println("来到过虑器了。。。");
chain.doFilter(request, response);//放行语句
}
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>
Filter的生命周期
- 创建
在服务器启动的时候就创建。
- 销毁
服务器停止的时候。
Filter执行顺序
- 客户端发出请求,先经过过滤器, 如果过滤器放行,那么才能到servlet
- 如果有多个过滤器, 那么他们会按照注册的映射顺序 来 排队。 只要有一个过滤器, 不放行,那么后面排队的过滤器以及咱们的servlet都不会收到请求。
Filter细节:
-
init方法的参数 FilterConfig , 可以用于获取filter在注册的名字 以及初始化参数。 其实这里的设计的初衷与ServletConfig是一样的。
-
如果想放行,那么在doFilter 方法里面操作,使用参数 chain
chain.doFilter(request, response); 放行, 让请求到达下一个目标。 -
/* 写法格式与servlet一样。
- 全路径匹配 以 / 开始
/LoginServlet - 以目录匹配 以 / 开始 以 * 结束
/demo01/* - 以后缀名匹配 以 * 开始 以后缀名结束
*.jsp *.html *.do
- 全路径匹配 以 / 开始
-
针对 dispatcher 设置
REQUEST : 只要是请求过来,都拦截,默认就是REQUEST
FORWARD : 只要是转发都拦截。
ERROR : 页面出错发生跳转
INCLUDE : 包含页面的时候就拦截。