首页 > 代码库 > Java Web总结二十Filter、装饰设计模式

Java Web总结二十Filter、装饰设计模式

一、Filter的部署——注册Filter

<filter>
         <filter-name>testFitler</filter-name>
         <filter-class>org.test.TestFiter</filter-class>
         <init-param>
           <param-name>word_file</param-name>    
           <param-value>/WEB-INF/word.txt</param-value>
         </init-param>
</filter>

    1、<filter-name>用于为过滤器指定一个名字,该元素的内容不能为空。

  2、<filter-class>元素用于指定过滤器的完整的限定类名。

  3、<init-param>元素用于为过滤器指定初始化参数,它的子元素<param-name>指定参数的名字,<param-value>指定参数的值。在过滤器中,可以使用FilterConfig接口对象来访问初始化参数。

二、Filter的部署——映射Filter

  1、<filter-mapping>元素用于设置一个 Filter 所负责拦截的资源。一个Filter拦截的资源可通过两种方式来指定:Servlet名称和资源访问的请求路径。

  2、<filter-name>子元素用于设置filter的注册名称。该值必须是在<filter>元素中声明过的过滤器的名字。

  3、<url-pattern>设置 filter 所拦截的请求路径(过滤器关联的URL样式)

  4、<servlet-name>指定过滤器所拦截的Servlet名称。

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

  6、<dispatcher> 子元素可以设置的值及其意义:

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

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

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

    (4)ERROR:如果目标资源是通过声明式异常处理机制调用时,那么该过滤器将被调用。除此之外,过滤器不会被调用。注意:一定要在web.xml文件声明错误代码或类型

<error-page>
      <error-code>500</error-code>
      <location>/sys_500.jsp</location>
</error-page>    
 
<filter-mapping>
    <filter-name>MappingFilter</filter-name>
    <url-pattern>/*</url-pattern>

    <dispatcher>ERROR</dispatcher>
</filter-mapping>

 三、装饰设计模式

  1、需求:当某个类的某个方法不适应当前业务的需要

  2、思路:(1)扩展父类的可供扩展的方法,可以使有,但不优;(2)装饰设计模式(推荐)

  3、开发步骤:

    (1)首先看需要被增强对象继承了什么接口或父类,编写一个类也去继承这些接口或父类或被增强对象本身。

    (2)在类中定义一个变量,变量类型即需增强对象的类型。

    (3)在类中定义一个构造函数,接收需增强的对象。

    (4)覆盖需增强的方法,编写增强的代码。

    (5)对于不想增强的方法,直接调用被增强对象的方法。

  4、案例:对BufferedReader进行装饰

package com.gnnuit.web.decorator;

import java.io.BufferedReader;
import java.io.IOException;

//对BufferedReader进行装饰
public class MyBufferedRead {
    private BufferedReader reader;
    private int no;

    public MyBufferedRead(BufferedReader reader) {
        this.reader = reader;
    }

    // 重写父对象的方法
    public String readLine() throws IOException {
        String line = reader.readLine();
        if (line != null) {
            no++;
            line = no + ":" + line;
        }
        return line;
    }

    // 真接使用父对象的方法
    public void close() throws Exception {
        reader.close();
    }
}

 

四、