web过虑器

    |     2016年12月2日   |   Servlet与Jsp   |     0 条评论   |    1730

一、过虑器定义

过虑器是一个服务端实现javax.servlet.Filter接口的java类,它可以截取用户端的请求与服务端的响应信息,实现对这些信息过虑。可以实现以下目的:
1. 在客户端的请求访问后端资源之前,拦截这些请求。
2. 在服务器的响应发送回客户端之前,处理这些响应。

二、工作原理

20161202104427

三、过虑器配置与生命周期

实例化     web.xml
初始化     init()
过虑       doFilter()
销毁       destroy()

web.xml配置各节点说明

<filter>              指定一个过滤器。
 <filter-name>         用于为过滤器指定一个名字,该元素的内容不能为空。
    <filter-class>        元素用于指定过滤器的完整的限定类名。
    <init-param>          元素用于为过滤器指定初始化参数,它的子元素<param-name>指定参数的名字,<param-value>指定参数的值。在过滤器中,可以使用FilterConfig接口对象来访问初始化参数。
 <filter-mapping>      元素用于设置一个 Filter 所负责拦截的资源。一个Filter拦截的资源可通过两种方式来指定:Servlet 名称和资源访问的请求路径
    <filter-name>         子元素用于设置filter的注册名称。该值必须是在<filter>元素中声明过的过滤器的名字
    <url-pattern>         设置 filter 所拦截的请求路径(过滤器关联的URL样式)
 <servlet-name>        指定过滤器所拦截的Servlet名称。

例子:

public class LoginFilter implements Filter {
	public void destroy() {
		
	}
	public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
		// place your code here

		// pass the request along the filter chain
		chain.doFilter(request, response);
	}
	public void init(FilterConfig fConfig) throws ServletException {

	}
}

web.xml配置

<filter>
   <filter-name>LoginFilter </filter-name>
   <filter-class>com.ittx.test.LoginFilter </filter-class>
   <init-param>
    <param-name>test-param</param-name>
    <param-value>Initialization Paramter</param-value>
   </init-param>
</filter>

<filter>
   <filter-name>AuthenFilter</filter-name>
   <filter-class>com.ittx.test.AuthenFilter</filter-class>
   <init-param>
    <param-name>test-param</param-name>
    <param-value>Initialization Paramter</param-value>
   </init-param>
</filter>

<filter-mapping>
   <filter-name>LoginFilter </filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>

<filter-mapping>
   <filter-name>AuthenFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>

四、过虑链

一个web请求可以定义多个过虑器,它们按先后顺序组装在一起成为一条过虑链.
20161202105130

五、过虑器分类

REQUEST:当用户直接访问页面时,Web容器将会调用过滤器。如果目标资源是通过RequestDispatcher的include()或forward()方法访问时,那么该过滤器就不会被调用。

INCLUDE:如果目标资源是通过RequestDispatcher的include()方法访问时,那么该过滤器将被调用。除此之外,该过滤器不会被调用。

FORWARD:如果目标资源是通过RequestDispatcher的forward()方法访问时,那么该过滤器将被调用,除此之外,该过滤器不会被调用。

ERROR:如果目标资源是通过声明式异常处理机制调用时,那么该过滤器将被调用。除此之外,过滤器不会被调用。

在web.xml中配置
指定过滤器所拦截的资源被 Servlet 容器调用的方式,可以是REQUEST,INCLUDE,FORWARD和ERROR之一,默认REQUEST。用户可以设置多个子元素用来指定 Filter 对资源的多种调用方式进行拦截。

web监听器参见:如何使用监听器Servlet

转载请注明来源:web过虑器
回复 取消