`
jinnianshilongnian
  • 浏览: 21514050 次
  • 性别: Icon_minigender_1
博客专栏
5c8dac6a-21dc-3466-8abb-057664ab39c7
跟我学spring3
浏览量:2420553
D659df3e-4ad7-3b12-8b9a-1e94abd75ac3
Spring杂谈
浏览量:3010285
43989fe4-8b6b-3109-aaec-379d27dd4090
跟开涛学SpringMVC...
浏览量:5640616
1df97887-a9e1-3328-b6da-091f51f886a1
Servlet3.1规范翻...
浏览量:260239
4f347843-a078-36c1-977f-797c7fc123fc
springmvc杂谈
浏览量:1597965
22722232-95c1-34f2-b8e1-d059493d3d98
hibernate杂谈
浏览量:250375
45b32b6f-7468-3077-be40-00a5853c9a48
跟我学Shiro
浏览量:5860624
Group-logo
跟我学Nginx+Lua开...
浏览量:702890
5041f67a-12b2-30ba-814d-b55f466529d5
亿级流量网站架构核心技术
浏览量:785763
社区版块
存档分类
最新评论

Servlet3.1规范翻译——过滤器

 
阅读更多

 

过滤器

过滤器(Filter)是Java组件,允许运行过程中改变进入资源的请求和资源返回的响应中的有效负载和header信息。

 

本章描述了Java Servlet v3.0 API类和方法,它们提供了一种轻量级的框架用于过滤动态和静态内容。还描述了如何在Web应用配置Filter,它们实现的约定和语义。

 

网上提供了Servlet 过滤器的API文档。过滤器的配置语法在第14章的“部署描述符”中的部署描述符模式部分给出。当阅读本章时,读者应该是一这些资源作为参考。

 

6.1 什么是过滤器

过滤器是一种代码重用的技术,它可以改变HTTP请求的内容,响应,及header信息。过滤器通常不产生响应或像servlet那样对请求作出响应,而是修改或调整到资源的请求,修改或调整来自资源的响应。

 

过滤器可以作用于动态或静态内容。这章说的动态和静态内容指的是Web资源。

 

供开发人员使用的过滤器功能有如下几种类型:

在执行请求之前访问资源。

在执行请求之前处理资源的请求。

用请求对象的自定义版本包装请求对请求的header和数据进行修改。

用响应对象的自定义版本包装响应对响应的header和数据进行修改。

拦截资源调用之后的调用。

作用在Servlet,一组Servlet,或静态内容上的零个,一个或多个拦截器按指定的顺序执行。

 

6.1.1 过滤器组件示例

验证过滤器

日志记录和审计过滤器

图像转换过滤器

数据压缩过滤器

加密过滤器

词法(Tokenizing)过滤器

触发资源访问事件过滤器

转换XML内容的XSL/T过滤器

MIME-类型链过滤器

缓存过滤器

 

6.2 主要概念

本章描述了过滤器模型的主要概念。

 

应用开发人员通过实现javax.servlet.Filter接口并提供一个公共的空参构造器来创建过滤器。该类及构建Web应用的静态资源和Servlet打包在Web应用归档文件中。Filter在部署描述符中通过<filter>元素声明。一个过滤器或一组过滤器可以通过在部署描述符中定义<filter-mapping>来为调用配置。可以使用servlet的逻辑视图名把过滤器映射到一个特定的servlet,或者使用URL模式把一组Servlet和静态内容资源映射到过滤器。

 

6.2.1 过滤器生命周期

Web应用部署之后,在请求导致容器访问Web资源之前,容器必须找到过滤器列表并按照如上所述的应用到Web资源。容器必须确保它为过滤器列表中的每一个都实例化了一个适当类的过滤器,并调用其init(FilterConfig config)方法。过滤器可能会抛出一个异常,以表明它不能正常运转。如果异常的类型是UnavailableException,容器可以检查异常的isPermanent属性并可以选择稍候重试过滤器。

 

在部署描述符中声明的每个<filter>在每个JVM的容器中仅实例化一个实例。容器提供了声明在过滤器的部署描述符的过滤器config(译者注:FilterConfig),对Web应用的ServletContext的引用,和一组初始化参数。

 

当容器接收到传入的请求时,它将获取列表中的第一个过滤器并调用doFilter方法,传入ServletRequest ServletResponse,和一个它将使用的FilterChain对象的引用。

 

过滤器的doFilter方法​​通常会被实现为如下或如下形式的子集:

1. 该方法检查请求的头。

2. 该方法可以用自定义的ServletRequestHttpServletRequest实现包装请求对象为了修改请求的头或数据。

3. 该方法可以用自定义的ServletResponse HttpServletResponse实现包装传入doFilter方法的响应对象用于修改响应的头或数据。

4. 该过滤器可以调用过滤器链中的下一个实体。下一个实体可能是另一个过滤器,或者如果当前调用的过滤器是该过滤器链配置在部署描述符中的最后一个过滤器,下一个实体是目标Web资源。调用FilterChain对象的doFilter方法将影响下一个实体的调用,且传入的它被调用时请求和响应,或传入它可能已经创建的包装版本。

由容器提供的过滤器链的doFilter方法的实现,必须找出过滤器链中的下一个实体并调用它的doFilter方法,传入适当的请求和响应对象。另外,过滤器链可以通过不调用下一个实体来阻止请求,离开过滤器负责填充响应对象。

service方法必须和应用到servlet的所有过滤器运行在同一个线程中。

5. 过滤器链中的下一个过滤器调用之后,过滤器可能检查响应的头。

6. 另外,过滤器可能抛出一个异常以表示处理过程中出错了。如果过滤器在doFilter处理过程中抛出UnavailableException,容器必须停止处理剩下的过滤器链。 如果异常没有标识为永久的,它或许选择稍候重试整个链。

7. 当链中的最后的过滤器被调用,下一个实体访问的是链最后的目标servlet或资源。

8. 在容器能把服务中的过滤器实例移除之前,容器必须先调用过滤器的destroy方法以便过滤器释放资源并执行其他的清理工作。

 

6.2.2 包装请求和响应

过滤器的核心概念是包装请求或响应,以便它可以覆盖行为执行过滤任务。在这个模型中,开发人员不仅可以覆盖请求和响应对象上已有的方法,也能提供新的API以适用于对过滤器链中剩下的过滤器或目标web资源做特殊的过滤任务。例如,开发人员可能希望用更高级别的输出对象如output stream writer来扩展响应对象,如API,允许DOM对象写回客户端。

 

为了支持这种风格的过滤器,容器必须支持如下要求。当过滤器调用容器的过滤器链实现的doFilter方法时,容器必须确保请求和响应对象传到过滤器链中的下一个实体,或如果过滤器是链中最后一个,将传入目标web资源,且与调用过滤器传入doFilter方法的对象是一样的。

 

当调用者包装请求或响应对象时,对包装对象的要求同样适用于从servlet或过滤器到RequestDispatcher.forward RequestDispatcher.include的调用。在这种情况下,调用servlet看到的请求和响应对象与调用servlet或过滤器传入的包装对象必须是一样的。      

 

6.2.3 过滤器环境

可以使用部署描述符中的<init-params>元素把一组初始化参数关联到过滤器。这些参数的名字和值在过滤器运行期间可以使用过滤器的FilterConfig对象的getInitParametergetInitParameterNames方法得到。另外,FilterConfig提供访问Web应用的ServletContext用于加载资源,记录日志,在ServletContext的属性列表存储状态。链中最后的过滤器和目标servlet或资源必须执行在同一个调用线程。

 

6.2.4 在Web应用中配置过滤器

过滤器可以通过规范的第8-67页的8.1.2节“@WebFilter”的@WebFilter注解定义或者在部署描述符中使用<filter>元素定义。在这个元素中,程序员可以声明如下内容:

filter-name: 用于映射过滤器到servletURL

filter-class: 由容器用于表示过滤器类型

init-params: 过滤器的初始化参数

程序员可以选择性的指定icon图标,文字说明,和工具操作显示的名字。容器必须为部署描述符中定义的每个过滤器声明实例化一个Java类实例。因此,如果开发人员对同一个过滤器类声明了两次,则容器将实例化两个相同的过滤器类的实例。

 

下面是一个过滤器声明的例子:

<filter>
    <filter-name>Image Filter</filter-name>
    <filter-class>com.acme.ImageFilter</filter-class>
</filter>

一旦在部署描述符中声明了过滤器,装配人员使用<filter-mapping>定义Web应用中的servlet和静态资源到过滤器的应用。过滤器可以使用<servlet-name>元素关联到一个Servlet。例如,以下示例代码映射Image Filter过滤器到ImageServlet servlet

 

<filter-mapping>
    <filter-name>Image Filter</filter-name>
    <servlet-name>ImageServlet</servlet-name>
</filter-mapping> 

过滤器可以使用<url-pattern>风格的过滤器映射关联到一组servlet和静态内容:

<filter-mapping>
    <filter-name>Logging Filter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
 

在这里, Logging过滤器应用到Web应用中的所有servlet和静态资源,因为每一个请求的URI匹配‘/*’URL模式。

 

当使用<url-pattern>风格配置<filter-mapping>元素,容器必须使用定义在12章“映射请求到Servlet”中的路径映射规则(path mapping rule)决定<url-pattern>是否匹配请求URI

 

容器使用的用于构建应用到一个特定请求URI的过滤器链的顺序如下所示:

1. 首先, <url-pattern>按照在部署描述符中的出现顺序匹配过滤器映射。

2. 接下来,<servlet-name>按照在部署描述符中的出现顺序匹配过滤器映射。

 

如果过滤器映射同时包含了<servlet-name> <url-pattern>,容器必须展开过滤器映射为多个过滤器映射(每一个<servlet-name> <url-pattern>一个),按照<servlet-name> <url-pattern>元素顺序。例如,以下过滤器映射:

<filter-mapping>
    <filter-name>Multipe Mappings Filter</filter-name>
    <url-pattern>/foo/*</url-pattern>
    <servlet-name>Servlet1</servlet-name>
    <servlet-name>Servlet2</servlet-name>
    <url-pattern>/bar/*</url-pattern>
</filter-mapping>

等价于:

 

<filter-mapping>
    <filter-name>Multipe Mappings Filter</filter-name>
    <url-pattern>/foo/*</url-pattern>
</filter-mapping>
<filter-mapping>
    <filter-name>Multipe Mappings Filter</filter-name>
    <servlet-name>Servlet1</servlet-name>
</filter-mapping>
<filter-mapping>
    <filter-name>Multipe Mappings Filter</filter-name>
    <servlet-name>Servlet2</servlet-name>
</filter-mapping>
<filter-mapping>
    <filter-name>Multipe Mappings Filter</filter-name>
    <url-pattern>/bar/*</url-pattern>
</filter-mapping>

关于过滤器链顺序的要求意味着容器,当接收到传入的请求,按照如下方式处理请求:

按照120页的“映射规则”识别目标Web资源。

如果有过滤器使用servlet name匹配到具有<servlet-name>Web资源,容器以声明在部署描述符中的顺序构建过滤器链。该链中的最后一个过滤器,即最后一个<servlet-name> 匹配的过滤器将调用目标Web资源。

如果有过滤器使用<url-pattern>匹配且该<url-pattern>按照第12.2节“映射规则”中的规则匹配请求的URI,容器容器以声明在部署描述符中的顺序构建<url-pattern>匹配到的过滤器链。该链中的最后一个过滤器是在部署描述符中对当前请求URI最后一个<url-pattern>匹配的过滤器。链中的最后一个过滤器将调用<servlet-name>匹配的链中的第一个过滤器,或如果没有,则调用目标Web资源。

 

想要高性能Web容器将缓存过滤器链从而不需要根据每个请求重新计算它们。

 

6.2.5 过滤器和RequestDispatcher

Java Servlet规范自从2.4新版本以来,能够在请求分派器forward()include()调用情况下配置可被调用的过滤器。

 

通过在部署描述符中使用新的<dispatcher>元素,开发人员可以为filter-mapping指定是否想要过滤器应用到请求,当:

1. 请求直接来自客户端。

可以由一个带有REQUEST 值的<dispatcher>元素,或者没有任何<dispatcher>元素来表示。

2.使用表示匹配<url-pattern> <servlet-name>Web组件的请求分派器的forward()调用情况下处理请求。

可以由一个带有FORWARD值的<dispatcher>元素表示。

3.使用表示匹配<url-pattern> <servlet-name>Web组件的请求分派器的include()调用情况下处理请求。

可以由一个带有INCLUDE值的<dispatcher>元素表示。

4. 使用第106页“错误处理”指定的错误页面机制处理匹配<url-pattern>的错误资源的请求。

可以由一个带有ERROR值的<dispatcher>元素表示。

5. 使用第10页指定的“异步处理”中的异步上下文分派机制对web组件使用dispatch调用处理请求。

可以由一个带有ASYNC值的<dispatcher>元素表示。

6. 或之上12345的任何组合。

 

例如:

<filter-mapping>
    <filter-name>Logging Filter</filter-name>
    <url-pattern>/products/*</url-pattern>
</filter-mapping> 

客户端以/products/...开始的请求将导致Logging Filter被调用,但不是在以路径/products/...开始的请求分派器调用情况下。LoggingFilter 将在初始请求分派和恢复请求时被调用。如下代码:

<filter-mapping>
    <filter-name>Logging Filter</filter-name>
    <servlet-name>ProductServlet</servlet-name>
    <dispatcher>INCLUDE</dispatcher>
</filter-mapping>
 

客户端到ProductServlet的请求将不会导致Logging Filter被调用,且也不会在请求分派器forward()调用到ProductServlet情况时,仅在以ProductServlet名字开头的请求分派器 include()调用时被调用。如下代码:

<filter-mapping>
    <filter-name>Logging Filter</filter-name>
    <url-pattern>/products/*</url-pattern>
    <dispatcher>FORWARD</dispatcher>
    <dispatcher>REQUEST</dispatcher>
</filter-mapping>

 

客户端以/products/...开始的请求,或在以路径/products/...开始的请求分派器forward()调用情况时,将导致Logging Filter被调用。最后,如下代码使用特殊的servlet名字 “*”:

 <filter-mapping>

    <filter-name>All Dispatch Filter</filter-name>
    <servlet-name>*</servlet-name>
    <dispatcher>FORWARD</dispatcher>
</filter-mapping>

 

该代码在按名字或按路径获取的所有请求分派器forward()调用时将导致All Dispatch Filter被调用。

 

 

 

PS:希望大家不吝指正翻译中的错误,希望有兴趣的iteye朋友加入进来一起翻译和学习

 

Servlet3.1JSR340)规范目前处于早期草案阶段,目标是在Java EE 7或更高平台。 Servlet3.0JSR 315)已经包含在Java EE 6平台。具体请参考本规范网站:http://jcp.org/en/jsr/detail?id=340

6
20
分享到:
评论
9 楼 inotgaoshou 2012-11-28  
jinnianshilongnian 写道
elam 写道
jinnianshilongnian 写道
elam 写道
jinnianshilongnian 写道
elam 写道
我的意思是这篇文章是给初学者看的话应该写一点用filter的注意事项
比如不要在filter里写消耗过大的逻辑

这个是servlet3.1规范翻译   不是自己写的

可以翻译+批注嘛
笔记也可以很热销的

  想赶紧翻译完,现在每天晚上都是翻译这东西。有兴趣做批注不 我可以把原始资料给你

心有余而力不足
楼主时间这么充裕  让人羡慕啊

,白天也要上班的,都是晚上和周末翻译。。。

涛 哥v5~!
8 楼 jinnianshilongnian 2012-11-28  
elam 写道
jinnianshilongnian 写道
elam 写道
jinnianshilongnian 写道
elam 写道
我的意思是这篇文章是给初学者看的话应该写一点用filter的注意事项
比如不要在filter里写消耗过大的逻辑

这个是servlet3.1规范翻译   不是自己写的

可以翻译+批注嘛
笔记也可以很热销的

  想赶紧翻译完,现在每天晚上都是翻译这东西。有兴趣做批注不 我可以把原始资料给你

心有余而力不足
楼主时间这么充裕  让人羡慕啊

,白天也要上班的,都是晚上和周末翻译。。。
7 楼 elam 2012-11-28  
jinnianshilongnian 写道
elam 写道
jinnianshilongnian 写道
elam 写道
我的意思是这篇文章是给初学者看的话应该写一点用filter的注意事项
比如不要在filter里写消耗过大的逻辑

这个是servlet3.1规范翻译   不是自己写的

可以翻译+批注嘛
笔记也可以很热销的

  想赶紧翻译完,现在每天晚上都是翻译这东西。有兴趣做批注不 我可以把原始资料给你

心有余而力不足
楼主时间这么充裕  让人羡慕啊
6 楼 jinnianshilongnian 2012-11-28  
elam 写道
jinnianshilongnian 写道
elam 写道
我的意思是这篇文章是给初学者看的话应该写一点用filter的注意事项
比如不要在filter里写消耗过大的逻辑

这个是servlet3.1规范翻译   不是自己写的

可以翻译+批注嘛
笔记也可以很热销的

  想赶紧翻译完,现在每天晚上都是翻译这东西。有兴趣做批注不 我可以把原始资料给你
5 楼 elam 2012-11-28  
jinnianshilongnian 写道
elam 写道
我的意思是这篇文章是给初学者看的话应该写一点用filter的注意事项
比如不要在filter里写消耗过大的逻辑

这个是servlet3.1规范翻译   不是自己写的

可以翻译+批注嘛
笔记也可以很热销的
4 楼 jinnianshilongnian 2012-11-28  
elam 写道
我的意思是这篇文章是给初学者看的话应该写一点用filter的注意事项
比如不要在filter里写消耗过大的逻辑

这个是servlet3.1规范翻译   不是自己写的
3 楼 elam 2012-11-28  
我的意思是这篇文章是给初学者看的话应该写一点用filter的注意事项
比如不要在filter里写消耗过大的逻辑
2 楼 jinnianshilongnian 2012-11-28  
elam 写道
使用filter会对性能造成一定影响的吧

这个要看你怎么用了,而且你的性能是怎么定义的。

比如使用AOP实现容器管理事务,肯定比不用要慢,但如果你可以接受这个时间,那就不是性能问题。
1 楼 elam 2012-11-28  
使用filter会对性能造成一定影响的吧

相关推荐

    servlet3.1规范

    Java Servlet 3.1 规范是Java Web开发中的一个重要里程碑,它定义了Servlet容器(如Tomcat、Jetty)与Web应用程序之间的交互标准。这个规范不仅提供了对HTTP协议的处理,还包括了对WebSocket、异步处理、依赖注入等...

    Servlet3.1规范.docx

    注解允许开发者在类或方法级别声明servlet、过滤器和监听器,减少了web.xml配置文件的需求。异步处理允许servlet在非阻塞模式下处理请求,提高了系统性能。WebSocket支持则提供了双向通信的能力,为实时应用提供了...

    servletser

    3. **servlet-3_1-final.pdf** 和 **Servlet3.1规范(最终版).pdf**:这两个文件都是Servlet 3.1版本的最终规范文档,该版本引入了诸如异步处理、注解配置、过滤器链等功能增强。 4. **servlet-2_3-fcs-spec.pdf**...

    SpringMVC 3.1 体验

    同时,MVC的DispatcherServlet支持过滤器链,可以方便地集成各种过滤器,如GZIP压缩、CSRF防护等。 至于压缩包中的`TestSpringMVC`文件,很可能是该项目的入口点或者测试用例。它可能包含了配置文件(如`web.xml`和...

    Core_Servlets_and_JavaServer_Pages

    在开发过程中,还会涉及到Web应用程序的部署描述符(web.xml),这是一个XML文件,用于配置Servlet、过滤器和监听器等组件。此外,JSTL(JavaServer Pages Standard Tag Library)和EL(Expression Language)可以...

    JAVA WEB 开发详解:XML+XSLT+SERVLET+JSP 深入剖析与实例应用.part3

    20.5 对用户进行统一验证的过滤器 594 20.6 对请求和响应数据进行替换的 20.6 过滤器 600 20.7 小结 609 第21章 中文乱码问题与国际化 610 21.1 中文乱码问题产生的由来 610 21.1.1 常用字符集 610 21.1.2 对...

    jspservlet取参数乱码问题分析

    在Java Web开发中,尤其是在处理中文参数时,经常会遇到一个常见问题——**jspservlet取参数乱码**。这一现象通常发生在当用户从客户端提交包含中文字符的表单至服务器端时,服务器端接收到的参数显示为乱码。这种...

    Java Web编程宝典-十年典藏版.pdf.part2(共2个)

    5.4 一夫当关——配置并应用Servlet过滤器 5.4.1 过滤器的基本原理 5.4.2 过滤器的核心API 5.4.3 过滤器的创建与配置 5.4.4 JavaWeb中字符乱码分析 5.4.5 实现字符编码过滤器 5.5 实战检验 5.5.1 通过Servlet实现...

    AJAX入门学习——ajax4jsf

    - **避免使用过滤器导致布局问题**:确保过滤器不会影响AJAX响应。 - **表单提交问题**:确保使用了正确的组件和事件序列。 - **创建延迟渲染区域**:使用`a4j:support`组件。 - **停止轮询**:使用`a4j:poll`组件的...

    Tomcat678.rar

    1. **支持新标准**:支持Servlet 3.0、JSP 2.2和EL 2.2,引入了如异步处理、过滤器链和注解等新特性。 2. **NIO(非阻塞I/O)**:添加了对Java NIO的支持,提高了高并发场景下的性能。 3. **Web应用部署**:支持热...

    springMVC配置

    例如,这里配置了一个名为`encodingFilter`的过滤器,指定编码为`UTF-8`,并且只对以`.do`结尾的URL进行过滤。 ```xml &lt;filter-name&gt;encodingFilter &lt;filter-class&gt;org.springframework.web.filter....

    Java Web程序设计教程

    3.1开发第一个jsp+servlet应用 33 3.1.1创建工程 33 3.1.2编写程序 34 3.1.3部署应用 35 3.2认识jsp 36 3.2.1jsp的工作原理 37 3.2.2jsp注释方式 37 3.2.3jsp声明方式 38 3.2.4jsp表达式的应用 39 3.2.5jsp...

    SpringSecurity 3.0.1.RELEASE.CHM

    7.4. 使用其他过滤器 —— 基于框架 8. 核心安全过滤器 8.1. FilterSecurityInterceptor 8.2. ExceptionTranslationFilter 8.2.1. AuthenticationEntryPoint 8.2.2. AccessDeniedHandler 8.3. ...

    struts

    - **部署描述符**:`web.xml`文件是Web容器加载应用时的第一个入口,用于声明Struts的监听器和过滤器等组件。 - 声明Struts的监听器,用于初始化Struts框架。 - 定义Struts过滤器,拦截所有请求并交给Struts处理。...

    李兴华 Java Web 开发实战经典_带源码_高清pdf 带书签 上

    9.10.1、过滤器的基本概念 9.10.2、实现过滤器 9.10.3、过滤器的应用 9.11、监听器 9.11.1、对application监听 9.11.2、对session监听 9.11.3、对request监听 9.11.4、监听器实例 —— 在线人员统计 9.12、...

    MLDN+李兴华+Java+Web开发实战经典.part3.rar )

    9.10.1、过滤器的基本概念 9.10.2、实现过滤器 9.10.3、过滤器的应用 9.11、监听器 9.11.1、对application监听 9.11.2、对session监听 9.11.3、对request监听 9.11.4、监听器实例 —— 在线人员统计 ...

    李兴华 java_web开发实战经典 源码 完整版收集共享

    9.10.1、过滤器的基本概念 9.10.2、实现过滤器 9.10.3、过滤器的应用 9.11、监听器 9.11.1、对application监听 9.11.2、对session监听 9.11.3、对request监听 9.11.4、监听器实例 —— 在线人员统计 9.12、...

    李兴华 Java Web 开发实战经典_带源码_高清pdf 带书签 下

    9.10.1、过滤器的基本概念 9.10.2、实现过滤器 9.10.3、过滤器的应用 9.11、监听器 9.11.1、对application监听 9.11.2、对session监听 9.11.3、对request监听 9.11.4、监听器实例 —— 在线人员统计 9.12、...

    李兴华Java Web开发实战经典.pdf (高清版) Part1

    9.10.1、过滤器的基本概念 9.10.2、实现过滤器 9.10.3、过滤器的应用 9.11、监听器 9.11.1、对application监听 9.11.2、对session监听 9.11.3、对request监听 9.11.4、监听器实例 —— 在线人员统计 ...

Global site tag (gtag.js) - Google Analytics