JAVAEE——拦截器Filter
2018-04-12 本文已影响26人
So_ProbuING
过滤器Filter
filter的简介
filter是对客户端访问资源的过滤,符合条件放行,不符合条件不放行,并且可以对目标资源访问前后进行逻辑处理
快速入门
- 步骤:
1 编写一个过滤器的类实现Filter接口
2 实现接口中尚未实现的方法(着重实现doFilter方法)
3 在web.xml中进行配置(主要是配置要对哪些资源进行过滤)
public class QuickFilter2 implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
System.out.println("quick1 running");
//放行请求
chain.doFilter(request, response);
}
@Override
public void destroy() {
}
}
xml配置
url-pattern:代表要过滤的资源的匹配
filter-name:过滤器名称
filter-class:过滤器包名路径
<filter>
<filter-name>QuickFilter2</filter-name>
<filter-class>com.probuing.web.filter.QuickFilter1</filter-class>
</filter>
<filter-mapping>
<filter-name>QuickFilter2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
filter的访问流程.png
filter生命周期及其与生命周期相关的方法
Filter接口有三个方法,并且这个三个都是与Filter的生命相关的方法
- init(Filterconfig):代表filter对象初始化方法 filter对象创建时执行
- doFilter(ServletRequest,ServletResponse,FilterCha):代表filter执行过滤的核心方法,如果某资源在已经被配置到这个filter进行过滤的话,那么每次访问这个资源都会执行doFilter方法
- destory():代表是filter销毁方法 当filter对象销毁时执行该方法
Filter对象的生命周期:
- Filter何时创建:服务器启动时就创建该filter对象
- Filter何时销毁:服务器关闭时filter销毁
Filter的AP详解
1.init(FilterConfig)
Filter创建的时候会去执行init方法
其中参数config代表 该Filter对象的配置信息的对象,内部封装是该filter的配置信息。
图片.png
2.destory()方法
filter对象销毁时执行
3.doFilter方法
doFilter(ServletRequest,ServletResponse,FilterChain)
其中的参数:
- ServletRequest/ServletResponse:每次在执行doFilter方法时 web容器负责创建一个request和一个response对象作为doFilter的参数传递进来。该request个该response就是在访问目标资源的service方法时的request和response。
- FilterChain:过滤器链对象,通过该对象的doFilter方法可以放行该请求
Filter的配置
图片.pngurl-pattern配置时
- 完全匹配 /sertvle1
- 目录匹配 /aaa/bbb/* ----最多的
- /user/*:访问前台的资源进入此过滤器
- /admin/*:访问后台的资源时执行此过滤器
- 扩展名匹配 *.abc *.jsp
注意:url-pattern可以使用servlet-name替代,也可以混用
<url-pattern>/Servlet1</url-pattern>等同于
<servlet-name>Servlet1</servlet-name>
dispatcher:访问的方式(了解)
REQUEST:默认值,代表直接访问某个资源时执行filter
FORWARD:转发时才执行filter
INCLUDE: 包含资源时执行filter
ERROR:发生错误时 进行跳转是执行filter
<filter-mapping>
<filter-name>QuickFilter2</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>REQUEST</dispatcher>
</filter-mapping>