`

Filter过滤器

 
阅读更多

过滤器Filter

    过滤器,即在源数据和目的数据之间起过滤作用的组件.对web应用程序来说,过滤器是一个驻留在服务器端的Web组件,它可以截取客户端和资源之间的请求与响应信息,并对这些信息进行过滤.

    当Web容器接收到一个对资源的请求时,容器将判断是否有过滤器与该资源相关联.如果有,那么容器将把请求交给过滤器进行处理.在过滤器中,我们可以改变请求的内容,或者重新设置请求的报头信息,然后再将请求发送给目标资源.当目标资源对请求作出响应时,容器同样会将响应先转发给过滤器,在过滤器中,可以对响应的内容进行转换,然后再将响应发送客户端.


    从上述过程可以看出,客户端和目标资源并不需要知道过滤器的存在.即在Web应用程序中部署的过滤器,过滤器对客户端和目标资源来说是透明的.

 

    在一个Web应用程序中,可以部署多个过滤器,这些过滤器组成了一个过滤器链.过滤器链中的每个过滤器负责特定的操作和任务,客户端的请求在这些过滤器之间传递,直接到目标资源.在请求资源时,过滤器链中的过滤器将依次对请求进行处理,并将请求传递给下一个过滤器,直到目标资源,在发送响应时,则按照相反的顺序对响应进行处理,直到客户端.

    过滤器并不是必须要将请求传送到下一个过滤器(或目标资源),它也可以自行对请求进行处理,然后发送响应给客户端,或者将请求转发给另一个目标资源.

    下面是过滤器在Web开发中的一些主要应用:

对用户请求进行统一验证

对用户的访问请求进行记录和审核

对用户发送的数据进行过滤或替换

转换图像格式

对响应内容进行压缩,减少传输量

对请求和响应进行加密处理

触发资源访问事件

对XML的输出应用XSLT

 

 

Filter API

    过滤器开发相关的接口与类都包含在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类

 

 

Filter接口

    开发过滤器需要实现Filter接口,并提供一个公开的不带参数的构造方法.注意:开发过滤器没有现成的类可以继承.

    Filter接口定义了如下3个方法:

void init(FilterConfig filterConfig) throws ServletExpection

    Web容器调用该方法初始化过滤器.容器在调用该方法时,向过滤器传递FilterConfig类似.利用FilterConfig对象可以得到ServletContext对象,以及在部署描述符中配置的过滤器的初始化参数.这个方法抛出ServletExpection异常,通知容器该过滤器不能正常工作.

 

void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws java.io.IOException,ServletExpection

    doFilter()方法类似于Servlet接口的Service()方法.当客户端请求目标资源的时候,容器就会调用这个目标资源相关联的过滤器的doFilter()方法.在这个方法中,可以对请求和响应进行处理,实现过滤器的特定功能.在特定的操作完成后,可以调用chain.doFilter(request,response)将请求传递给下一个过滤器(或目标资源),也可以直接向客户端返回响应,或利用RequestDispatcher的forward()方法和include()方法,以及HttpServletResponse的sendRediect()方法将请求转向到其他资源.需要注意的是,这个方法的请求和响应参数的类型是ServletRequest和ServletResponse,也就是说,过滤器的使用并不依赖于具体的协议.

 

void destroy() 

    Web容器调用该方法指示过滤器的生命结束.在这个方法中,可以释放过滤器使用的资源.

 

 

 

 

FilterConfig接口

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

    FilterConfig接口定义的方法:

String getFilterName()

    得到在部署描述符中指定的过滤器名字.

 

String getInitParameter(String name)

    返回在部署描述中指定的名字为name的初始化参数的值.如果这个参数不存在,该方法将返回null.

 

Enumeration getInitParameterNames()

    返回过滤器的所有初始化参数的名字的枚举集合.如果过滤器没有初始化参数.这个方法将返回一个空的枚举集合.

 

ServletContext getServletContext()

    返回Servlet上下文对象的引用.

 

 

 

FilterChain接口

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

    Filter接口只有定义了一个方法,如下:

void doFilter(ServletRequest request, ServletResponse response) 

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

 

 

过滤器的部署

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

 

 

 

对请求和响应数据进行替换的过滤器

    常见情况.

留言板中用户嵌入恶意HTML,js代码.

用户输入不和谐语句.

    这些情况,需要对原有代码进行修改.但是又不想轻易的改变原有的代码.这时就可以利用过滤器了.

 

    过滤器只可以截取请求和响应对象.但是无法对请求和响应对象进行修改.则可以使用利用请求和响应的包装类.

    这四个包装类分别实现了请求接口和响应接口: 

javax.servlet.ServletRequestWrapper类

javax.servlet.ServletResponseWrapper类

javax.servlet.http.HttpServletRequestWrapper类

javax.servlet.http.HttpServletResponseWrapper类

 

    从表面上看,这四个类就好像是真正的请求和响应类,不过实质上,它们在构造方法中接受真正的请求和响应对象,然后利用该对象的方法来完成自己需要实现的方法.包装类是装饰设计模式的运用.装饰设计模式提供了一种不使用继承而修改或增加现有对象功能的方法.

 

 

 

  • 大小: 14.6 KB
  • 大小: 26 KB
分享到:
评论

相关推荐

    java 中如何使用filter过滤器

    本文将详细介绍如何在Java中使用Filter过滤器,以及如何配置相关的配置文件,让你一目了然。 ### 1. Filter接口与生命周期 Filter是Servlet API中的一个接口,位于`javax.servlet`包下。它定义了三个关键方法: -...

    Filter过滤器(分类讨论,分类讲解)

    ### Filter过滤器(分类讨论,分类讲解) #### 一、Filter概述 在Java Web开发中,`Filter`是一种非常重要的技术,它可以在请求到达目标资源(如Servlet或JSP页面)之前进行预处理,或者在响应返回客户端之前进行...

    SpringBoot的filter过滤器(源代码)

    SpringBoot的filter过滤器 一、过滤器的作用和概述 1.1 简述 1.2 使用场景 二、自定义过滤的两种方式 2.1 第一种方式 2.1.1 启动类增加注解@ServletComponentScan 2.1.2 定义一个filter类 2.1.3. 测试 2.2 第二种...

    ffmpeg filter过滤器基础实例以及全面解析

    FFmpeg Filter 过滤器是FFmpeg项目中用于音视频数据处理的一个重要组件,通过libavfilter库提供丰富的视频和音频过滤功能。这些过滤器可以在不同阶段对媒体数据进行操作,包括但不限于格式转换、帧率调整、大小缩放...

    如何配置Filter过滤器处理JSP中文乱码

    【如何配置Filter过滤器处理JSP中文乱码】 在开发Java Web应用时,尤其是在处理包含中文字符的请求时,可能会遇到中文乱码的问题。解决这个问题的一种常见方法是使用Filter过滤器。以下是配置Filter过滤器处理JSP...

    PHP Filter过滤器全面解析

    PHP Filter过滤器是PHP中用于处理和验证非安全来源数据的工具,特别是在处理用户输入时。这些过滤器有助于确保应用程序接收到的是预期的数据类型,从而提高应用的安全性和稳定性。过滤器扩展使得数据过滤过程变得...

    filter过滤器的简单使用.rar

    在标题提到的"filter过滤器的简单使用.rar"压缩包中,很显然包含了一个关于如何在Maven项目和Spring Boot项目中使用Filter的示例。下面将详细介绍Filter的基本概念、工作原理以及如何在两种项目环境中应用。 **...

    filter过滤器防止恶意注入

    在Java Web开发中,`Filter`过滤器是一个关键的安全组件,用于拦截并处理HTTP请求和响应。本示例中的`URLfilter`类就是一个简单的过滤器,它的主要目的是防止SQL注入攻击,这是一种常见的恶意攻击手段,攻击者试图...

    YII Framework的filter过滤器用法分析

    YII框架中的filter过滤器是该框架提供的一个强大功能,它允许开发者在控制器动作执行之前或之后执行一段自定义的代码,用以完成如访问控制、性能监控、数据验证等任务。过滤器的实现方式可以是通过控制器类中的特定...

    jsp filter 过滤器判断用户是否登录

    下面我们就通过分析一个具体的示例代码来详细了解如何使用JSP Filter过滤器来判断用户是否已经登录。 #### 示例代码分析 首先,我们来看一下示例中的过滤器类`RightFilter`: ```java import javax.servlet....

    java filter过滤器

    【Java Filter过滤器详解】 Java Filter是Java Servlet技术的一部分,它允许开发者在Servlet容器中对HTTP请求和响应进行拦截处理,实现数据过滤、权限控制、日志记录等多种功能。Filter的生命周期包括三个主要方法...

    Socket通信,封包处理, Filter过滤器处理

    Filter过滤器处理则是在数据传输或处理流程中添加的一层逻辑,用于拦截、修改或者增强数据。 首先,我们来深入理解Socket通信。Socket可以视为网络上的两个程序之间的一个连接点,通过这个连接点,数据可以在它们...

    Filter过滤器1

    Filter 过滤器 Filter 过滤器是 JavaWeb 的一个重要组件,对请求和响应进行拦截,实现一些特殊的功能。Filter 程序是一个实现 Filter 接口的 Java 类,类似于 Servlet 程序,由 Servlet 容器进行调用和执行。需要在...

    filter 过滤器 解释 MultipartHttpServletRequest表单

    filter 过滤器 解释 MultipartHttpServletRequest表单

    STRUTS:filter过滤器

    ### STRUTS:filter过滤器 #### 概述 在Java Web开发中,过滤器(Filter)是一种重要的组件,用于拦截客户端发送至服务器的请求或服务器返回至客户端的响应。Struts框架作为Java Web开发中的一种流行框架,利用了...

    15_尚硅谷_Filter过滤器_王振国 - 课堂笔记1

    Filter 过滤器详解 Filter 过滤器是 JavaWeb 的三大组件之一,另外两个组件是 Servlet 程序和 Listener 监听器。Filter 过滤器是一个接口,它的作用是拦截请求,过滤响应。常见的应用场景有权限检查、日记操作、...

    filter过滤器流程及中文乱码解决和客户端IP地址控制

    【filter过滤器流程】 在Java Web开发中,Filter(过滤器)是用于处理HTTP请求和响应的重要组件。它遵循Servlet规范中的Filter接口,允许开发者在请求到达目标Servlet或JSP之前以及响应离开Servlet之后进行拦截和...

    MVCFilter过滤器.rar

    "MVCFilter过滤器.rar"这个压缩包可能包含了一些关于如何在ASP.NET MVC中使用过滤器的示例或文档。 过滤器主要分为四类: 1. **授权过滤器(Authorization Filters)**:这类过滤器用于验证用户是否有权限访问某个...

    Lucene5学习之Filter过滤器

    《深入理解Lucene5:Filter过滤器的奥秘》 在全文搜索引擎的开发过程中,Lucene作为一款强大的开源搜索引擎库,扮演着至关重要的角色。它提供了丰富的功能,使得开发者能够快速构建高效的搜索系统。其中,Filter...

    Java-filter过滤器在项目开发中的应用.docx

    Java-filter过滤器在项目开发中的应用 Java-filter过滤器是一种Java EE规范中的一种组件,用于拦截和处理Servlet请求和响应。在项目开发中,Java-filter过滤器可以应用于解决各种问题,以下是其中的两种应用: ...

Global site tag (gtag.js) - Google Analytics