什么是Filter过滤器
- Web开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图片文件或静态 html 文件等进行拦截,从而实现一些特殊的功能。例如实现URL级别的权限访问控制、过滤敏感词汇、压缩响应信息等一些高级功能
- 它主要用于对用户请求进行预处理,也可以对HttpServletResponse进行后处理
- 在一个web应用中,可以开发编写多个Filter,这些Filter组合起来称之为一个Filter链
- web服务器根据Filter在web.xml文件中的注册顺序,决定先调用哪个Filter,当第一个Filter的doFilter方法被调用时,web服务器会创建一个代表Filter链的FilterChain对象传递给该方法。在doFilter方法中,开发人员如果调用了FilterChain对象的doFilter方法,则web服务器会检查FilterChain对象中是否还有filter,如果有,则调用第2个filter,如果没有,则调用目标资源
- 在doFilter()方法中,chain.doFilter()前的一般是对request执行的过滤操作,chain.doFilter后面的代码一般是对response执行的操作
- 在WEB开发中常见的应用的地方:
- 对用户请求进行统一认证,权限管理
- 对用户的访问请求进行记录和审核
- 对用户发送的数据进行过滤和替换
- 转换图像格式
- 对响应的内容进行压缩,减少传输量
- 对请求和相应进行加密处理
Filter开发
1.使用Filter的完整流程:Filter对用户请求进行预处理,接着将请求交给Servlet进行处理并生成响应,最后Filter再对服务器响应进行后处理
- 在HttpServletRequest到达 Servlet 之前,拦截客户的HttpServletRequest 。根据需要检查HttpServletRequest,也可以修改HttpServletRequest 头和数据。
- 在HttpServletResponse到达客户端之前,拦截HttpServletResponse 。根据需要检查HttpServletResponse,也可以修改HttpServletResponse头和数据。
3.Filter开发分为二个步骤:
- 编写java类实现Filter接口,并实现其doFilter方法
- 在 web.xml 文件中使用<filter>和<filter-mapping>元素对编写的filter类进行注册,并设置它所能拦截的资源
Filter生命周期
1.Filter创建
- public void init(FilterConfig filterConfig) throws ServletException; // 初始化
- Filter的创建和销毁由WEB服务器负责
- web 应用程序启动时,web 服务器将创建Filter 的实例对象,并调用其init方法,完成对象的初始化功能,从而为后续的用户请求作好拦截的准备工作
- filter对象只会创建一次,init方法也只会执行一次
- 通过init方法的参数,可获得代表当前filter配置信息的FilterConfig对象
2.Filter的doFilter()方法
- public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException; // 拦截请求
- 这个方法完成实际的过滤操作。当客户请求访问与过滤器关联的URL的时候,Servlet过滤器将先执行doFilter方法。
- FilterChain参数用于访问后续过滤器
3.filter的销毁
- public void destroy(); // 销毁
- Filter对象创建后会驻留在内存,当web应用移除或服务器停止时才销毁
- 在Web容器卸载 Filter 对象之前被调用
- 该方法在Filter的生命周期中仅执行一次。在这个方法中,可以释放过滤器使用的资源
FilterConfig对象
String getFilterName() // 得到filter的名称
String getInitParameter(String name) // 返回在部署描述中指定名称的初始化参数的值。如果不存在返回null
Enumeration getInitParameterNames(); // 返回过滤器的所有初始化参数的名字的枚举集合
ServletContext getServletContext() // 返回Servlet上下文对象的引用
Filter常用配置
<filter>
<description>FilterDemo02过滤器</description>
<filter-name>FilterDemo02</filter-name>
<filter-class>me.gacl.web.filter.FilterDemo02</filter-class>
<!--配置FilterDemo02过滤器的初始化参数-->
<init-param>
<description>配置FilterDemo02过滤器的初始化参数</description>
<param-name>name</param-name>
<param-value>gacl</param-value>
</init-param>
<init-param>
<description>配置FilterDemo02过滤器的初始化参数</description>
<param-name>like</param-name>
<param-value>java</param-value>
</init-param>
<!--映射过滤器-->
<filter-mapping>
<filter-name>FilterDemo02</filter-name>
<!--“/*”表示拦截所有的请求 -->
<url-pattern>/*</url-pattern>
</filter-mapping>
</filter>