Filter过滤器的hello world

helloWorld:
马克- to-win:马克 java社区:防盗版实名手机尾号: 73203。
马克-to-win:请同学们先做本部分的Filter的hello world实验。之后根据实验,再返回来学习我接下来的这段话。由于在web.xml当中,我们Filter的url-pattern是/*,所以当用户访问根目录下的任何目标文件时,我们这个Filter都会起作用。当发现用户要访问home.jsp时,MarkToWinFilter中的 doFilter方法会被运行。其中"之前 filterChain.doFilter"不出意外的会被打印出来。马克-to-win:接着就是chain.doFilter(request, response);方法。chain是什么?看那张说明“Filter的拦截的工作过程”的图了吗?那里面的1234567,7个步骤点,你不觉得就像一个chain(链儿)吗?所以chain.doFilter(request, response);的意思就是顺着链,继续往下走一步,就一步而已,继续执行。马克-to-win:如果还是Filter,就还是执行 chain.doFilter,如果是Servlet,就执行doXXX方法。Servlet执行完以后,别忘了,还要回来执行doFilter中的 chain.doFilter后面的部分。请大家仔细观察实验执行结果。


例 1.2.1
home.jsp:
<%@ page contentType="text/html; charset=GBK" %>
<%System.out.println("inside jsp"); %>
<br>这是在home.jsp<br>
MarkToWinFilter.java:
package com;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class MarkToWinFilter implements Filter {
    public MarkToWinFilter() {
        System.out.println("单独启动服务器时,constructor被运行,先于init");
    }
    public void destroy() {
        System.out.println("destroy服务器关闭时运行");
    }
    public void doFilter(ServletRequest request, ServletResponse response,
            FilterChain chain) throws IOException, ServletException {
/*下面这句话必须要。否则客户端浏览器里"之前"和"之后"两个词儿,中文就显示乱码。在chain上的response始终就是那一个,回写到客户端的结果先缓存在response当中,最后一并显示在客户端浏览器中。*/       
        response.setCharacterEncoding("GBK");
        PrintWriter out = response.getWriter();
        out.println("之前 filterChain.doFilter");
        System.out.println("之前 filterChain.doFilter");
        chain.doFilter(request, response);
        System.out.println("之后 filterChain.doFilter");
        out.println("之后 filterChain.doFilter");
    }
    public void init(FilterConfig fConfig) throws ServletException {
        System.out.println("单独启动服务器时,init被运行");
    }
}





在web.xml当中,加入以下的片段:

    <filter>
        <filter-name>MarkToWinFilter</filter-name>
        <filter-class>com.MarkToWinFilter</filter-class>
    </filter>
  <filter-mapping>
      <filter-name>MarkToWinFilter</filter-name>
      <url-pattern>/*</url-pattern>
  </filter-mapping>


在浏览器中,当运行home.jsp时,输出的结果是:
之前 filterChain.doFilter
这是在home.jsp
之后 filterChain.doFilter



Console当中输出的结果是:
之前 filterChain.doFilter
inside jsp
之后 filterChain.doFilter


看Console的记录,在服务器启动过程中,有这么两句话:
单独启动服务器时,constructor被运行,先于init
单独启动服务器时,init被运行