Filter概述

Filter 简介

      Filter 的基本功能是对 Servlet 容器调用 Servlet 的过程进行拦截,从而在 Servlet 进行响应处理的前后实现一些特殊的功能。

在 Servlet API 中定义了三个接口类来开供开发人员编写 Filter 程序:Filter, FilterChain, FilterConfig。

Filter 程序是一个实现了 Filter 接口的 Java 类,与 Servlet 程序相似,它由 Servlet 容器进行调用和执行。

     Filter 程序需要在 web.xml 文件中进行注册和设置它所能拦截的资源:Filter 程序可以拦截 Jsp, Servlet, 静态图片文件和静态 html 文件。

Filter 体系结构

     Filter并不是从真正意义上对来自客户端的请求做出最终响应,而是进行部分的过滤工作,对请求数据进行检测或者安全性检查等工作。

     Filter只有在客户端请求或者发出响应时才会自动进行调用,所以没有必要把这些Filter字节嵌入到整个Web应用系统的框架中,而是通过配置文件来设定。

     当然,大部分情况下,并不需要给Web应用程序设置Filter,因为它不是必需的。如果需要设置Filter,除了可以设置单个Filter关联外,还可以设置Web应用程序与一个Filter链(多个单Filter相串联)相关联。

Filter的工作过程的相关步骤:

  • 首先,通过部署描述器web.xml中对Filter的配置,特定Filter会捕捉到客户端的请求信息。
  • Filter调用内置方法来检查捕获到的请求对象,根据分析结果来决定是把该请求传递给下一个Filter(如果存在另一个Filter的话),还是中止该请求并向客户端发出一个响应。如果不存在Filter链,即仅仅为单个Filter,则上一个Filter直接把客户请求转发给Web服务器进行相应处理。
  • 如果CSS应用程序关联了Filter,在客户端请求设法通过各个Filter被服务器处理时,最终的响应将以相反的顺序通过Filter链,最后发送给客户端。

Filter 基本工作原理

     当在 web.xml 中注册了一个 Filter 来对某个 Servlet 程序进行拦截处理时,这个 Filter 就成了 Servlet 容器与该 Servlet 程序的通信线路上的一道关卡,该 Filter 可以对 Servlet 容器发送给 Servlet 程序的请求和 Servlet 程序回送给 Servlet 容器相应进行拦截,可以决定是否将请求继续传递给 Servlet 程序,以及对请求和相应信息是否进行修改。

在一个 web 应用程序中可以注册多个 Filter 程序,每个 Filter 程序都可以对一个或一组 Servlet 程序进行拦截。

     若有多个 Filter 程序对某个 Servlet 程序的访问过程进行拦截,当针对该 Servlet 的访问请求到达时,web 容器将把多个 Filter 程序组合成一个 Filter 链(过滤器链)。Filter 链中各个 Filter 的拦截顺序与它们在应用程序的 web.xml 中映射的顺序一致。

Filter的实现步骤

实现一个Filter的三个步骤:

  • 首先编写Filter的实现类程序。
  • 其次,需要把实现的Filter添加到Web应用程序中,也就是说,需要在Web部署描述文件Web.xml中声明该Filter。
  • 最后,将相关联的Filter与应用程序一起打包并部署。

Filter的主要作用及Filter API

Filter的主要作用

  • 对用户请求进行统一认证
  • 对用户的访问请求进行记录和审核
  • 对用户发送的数据进行过滤和替换
  • 转换图象格式
  • 对响应内容进行压缩,减少传输量
  • 对请求或响应进行加解密处理
  • 触发资源访问事件
  • 对XML的输出应用XSLT

Filter API

与Filter开发相关的接口与类都包含在javax.servlet和javax.servlet.http包中,主要有下面的接口和类。

  • javax.servlet.Filter接口
  • javax.servlet.FilterConfig接口
  • javax.servlet.FilterChain接口
  • javax.servlet.ServletRequestWrapper类
  • javax.servlet.ServletResponseWrapper类
  • javax.servlet.http.HttpServletRequestWrapper类
  • javax.servlet.http.HttpServletResponseWrapper类

FilterChain接口

     代表当前 Filter 链的对象,由容器实现,容器将其实例作为参数传入过滤器对象的doFilter()方法中。过滤器对象使用FilterChain对象调用过滤器链中的下一个过滤器,如果该过滤器是链中最后一个过滤器,那么将调用目标资源。

FilterChain接口只有一个方法。

FilterChain接口的方法

public void doFilter(ServletRequest request,ServletResponse response) throws IOException

调用该方法将使过滤器链中的下一个过滤器被调用。如果是最后一个过滤器,会调用目标资源。

FilterConfig接口

     javax.servlet.FilterConfig接口类似于javax.servlet.ServletConfig接口,用于在Filter初始化时向其传递信息。FilterConfig接口有容器实现,容器将其作为参数传入Filter对象的init()方法中。

在FilterConfig接口中,定义了四个方法。

FilterConfig接口的方法

public String getFilterName()

得到描述符中指定的过滤器的名字。

public String getInitParameter(String name)

返回在部署描述中指定的名字为name的初始化参数的值。如果不存在返回null。

public Enumeration getInitParameterNames()

返回过滤器的所有初始化参数的名字的枚举集合。

public ServletContext getSerlvetContext()

返回Servlet上下文对象的引用

Filter的部署

在实现一个Filter后,需要在部署描述符中对Filter进行配置,这是通过<filter>和<filter-mapping>元素来完成的。

<filter>元素

用于在Web应用程序中声明一个Filter。

在<filter>元素内,<description>、<display-name>、<icon>元素和以往serlvet的配置中的相同。

  • <filter-name>用于为Filter指定一个名称,该元素的内容不能为空。
  • <filter-class>元素用于指定Filter的完整的限定类名。
  • <init-param>元素用于为Filter指定初始化参数。它的子元素<param-name>指定参数的名称;<param-value>指定参数的值。

在Filter中,可以使用FilterConfig接口对象来访问初始化参数。

<filter-mapping>元素

用于指定Filter关联的url样式或者Servlet。

  • <filter-name>子元素的值必须是在<filter>元素中声明过的Filter的名字。
  • <url-pattern>元素指定Filter关联的URL样式。
  • <servlet-name>元素指定Filter对应的Servlet。

     <url-pattern>元素和<servlet-name>元素可以选择一个;用户在访问<url-pattern>元素指定的URL上的资源或<servlet-name>元素指定的Servlet时,该Filter才会被容器调用。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值