Tomcat过滤器简介

1.过滤器

1.1 过滤器简介

过滤器本身并不生成 ServletRequest对象和 ServletResponse对象,他只为 Web组件供如下过滤功能:

  • 过滤器能够在 Web组件被调用之前检查 ServletRequest对象,修改请求头和请求正文的内容,或者对请求进行预处理操作。
  • 过滤器能够在 Web组件被调用之后检查 ServletResponse对象,修改响应头和响应正文。

过滤器负责过滤的 Web组件可以是Servlet、JSP或HTML文件。
图1-1 过滤器的过滤过程

图1-1 过滤器的过滤过程

过滤器具有以下特点:

  • 过滤器可以检查ServletRequest对象和 ServletResponse对象,并且利用ServletRequestWrapper和 ServletResponseWrapper包装类来修改 ServletRequest对象和 ServletResponse对象。
  • 可以在 web.xml文件中为过滤器映射特定的 URL.当客户请求访问此 URL时,Servlet容器就会触发过滤器工作。
  • 多个过滤器可以被串联在一起,协同为 Web组件过滤请求对象和响应对象。

1.2 创建过滤器

所有自定义的过滤器类都必须实现 javax.servlet.Filter接口。这个接口含有3个过滤器类必须实现的方法:

  • init(FilterConfig config):这是过滤器的初始化方法。在Web应用启动时,Servlet容器先创建包含了过滤器配置信息的 FilterConfig对象,然后创建 Flter的对象,接着调用 Filter对象的 init(FilterConfig config)方法。在这个方法中可通过 config参数来读取web.xml文件中为过滤器配置的初始化参数。
  • doFilter(ServletRequest req, ServletResponse res, FilterChain chain):这个方法完成实际的过滤操作。当客户请求访问的 URL与为过滤器映射的 URL匹配时,Servlet容器将先调用过滤器的 doFilter()方法。FilterChain参数用于访问后续过滤器或者 Web组件。
  • destroy():Servlet容器在销毁过滤器对象前调用该方法,在这个方法中可以释放过滤器占用的资源。

过滤器由 Servlet容器创建,在它的生命周期中包含以下阶段:

  • 初始化阶段:当 Web应用启动时,Servlet容器会加载过滤器类,创建过滤器配置对象(FilterConfig)和过滤器对象,并调用过滤器对象的 init(FilterConfig config)方法。
  • 运行时阶段:当客户请求访问的 URL与为过滤器映射的 URL匹配时,Servlet容器将先调用过滤器的doFilter()方法。
  • 销毁阶段:当 Web应用终止时,Servlet容器先调用过滤器对象的destroy()方法,然后销毁过滤器对象。

1.3 发布过滤器

发布过滤器有两种办法:

  • 在 web.xml 文件中通过 <filter>元素和 <filter-mapping>元素来配置过滤器。
  • 在过滤器类中用 @WebFilter 标注来配置过滤器。

1.3.1 在 web.xml文件中配置过滤器

<filter>元素用来定义一个过滤器,如下所示:

<filter> 
    <filter-name>NoteFilter</filter-name> <!--指定过滤器名-->
    <filter-class>mypack.NoteFilter</filter-class> <!--指定过滤器的类名-->

    <!--为过滤器实例提供初始化参数,可在init()方法中通过config.getInitParameter(String name)读取-->
    <init-param>
        <param-name>ipblock</param-name>
        <param-value>221.45</param-value>
    </init-param>

    <init-param>
        <param-name>blacklist</param-name>
        <param-value>捣蛋鬼</param-value>
    </init-param>
</filter> 

<!--为过滤器映射特定的URL-->
<filter-mapping> 
    <filter-name>NoteFilter</filter-name> 
    <url-pattern>/note</url-pattern> 
</filter-mapping> 

注意:在 web.xml文件中,必须先配置所有过滤器,再配置Servlet。

1.3.2 用 @WebFilter标注来配置过滤器

@WebFilter过滤器标注的常用属性见下:

属性类型描述
filterNameString指定过滤器的名字,等价于<filter-name>
urlPatternsString[]指定一组待过滤的URL匹配模式,等价于<url-pattern>
valueString[]该属性等价于urlPatterns属性,但两者不应该同时使用
initParamsWebInitParam[]指定一组过滤器初始化参数,等价于</init-param>
asyncSupportedboolean声明过滤器是否支持异步处理模式,等下于<async-supported>
DescriptionString指定过滤器的描述信息,等价于<description>
displayNameString指定过滤器的显示名,通常配合工具使用,等价于<display-name>
dispatcherTypesDispatcherType指定过滤器的调用模式,可以指定多个值,用逗号分隔。具体取值包括:ASYNC、ERROR、FORWARD、INCLUDE、REQUEST

dispatcherTypes属性的具体取值为:

  • DispatcherType.REQUEST:当客户端直接请求访问待过滤的目标资源时,Web容器会先调用该过滤器。
  • DispatcherType.FORWARD:当待过滤的目标资源是通过RequestDispatcher 的 forward(请求转发)方式被访问时,Web容器会先调用该过滤器。
  • DispatcherType.INCLUDE:当待过滤的目标资源是通过RequestDispatcher 的 include(请求包含)方式被访问时,Web容器会先调用该过滤器。
  • DispatcherType.INCLUDE:当待过滤的目标资源是通过声明式异常处理机制被访问时,Web容器会先调用该过滤器。
  • DispatcherType.ASYNC:当待过滤的目标资源是被异常访问时,Web容器会先调用该过滤器。

对于 NoteFilter类的过滤器,可以加入如下 @WebFilter标注:

@WebFilter( //用@WebFilter标注配置NoteFilter
    filterName = "NoteFilter", 	
    urlPatterns = "/note", 	
    initParams = {
        @WebInitParam(name = "ipblock", value = "221.45"),			
        @WebInitParam(name = "blacklist", value = "捣蛋鬼")}
)
public class NoteFilter implements Filter {...}

1.4 串联过滤器

多个过滤器可以串联起来协同工作。Servlet容器将根据他们在web.xml中定义的先后顺序,依次调用它们的doFilter()方法。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值