/*
 * $Header: /home/cvs/jakarta-servletapi-5/jsr154/examples/WEB-INF/classes/filters/ExampleFilter.java,v 1.1 2002/09/02 13:14:53 remm Exp $
 * $Revision: 1.1 $
 * $Date: 2002/09/02 13:14:53 $
 *
 * ====================================================================
 *
 * The Apache Software License, Version 1.1
 *
 * Copyright (c) 1999 The Apache Software Foundation.  All rights
 * reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 *
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in
 *    the documentation and/or other materials provided with the
 *    distribution.
 *
 * 3. The end-user documentation included with the redistribution, if
 *    any, must include the following acknowlegement:
 *       "This product includes software developed by the
 *        Apache Software Foundation (http://www.apache.org/)."
 *    Alternately, this acknowlegement may appear in the software itself,
 *    if and wherever such third-party acknowlegements normally appear.
 *
 * 4. The names "The Jakarta Project", "Tomcat", and "Apache Software
 *    Foundation" must not be used to endorse or promote products derived
 *    from this software without prior written permission. For written
 *    permission, please contact [email protected].
 *
 * 5. Products derived from this software may not be called "Apache"
 *    nor may "Apache" appear in their names without prior written
 *    permission of the Apache Group.
 *
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 * ====================================================================
 *
 * This software consists of voluntary contributions made by many
 * individuals on behalf of the Apache Software Foundation.  For more
 * information on the Apache Software Foundation, please see
 * <http://www.apache.org/>.
 *
 * [Additional notices, if required by prior licensing conditions]
 *
 */
package filters;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
/**
 * Example filter that can be attached to either an individual servlet
 * or to a URL pattern.  This filter performs the following functions:
 * <ul>
 * <li>Attaches itself as a request attribute, under the attribute name
 *     defined by the value of the <code>attribute</code> initialization
 *     parameter.</li>
 * <li>Calculates the number of milliseconds required to perform the
 *     servlet processing required by this request, including any
 *     subsequently defined filters, and logs the result to the servlet
 *     context log for this application.
 * </ul>
 *
 * @author Craig McClanahan
 * @version $Revision: 1.1 $ $Date: 2002/09/02 13:14:53 $
 */public final class ExampleFilter implements Filter {
    // ----------------------------------------------------- Instance Variables
    /**
     * The request attribute name under which we store a reference to ourself.
     */
    private String attribute = null;
    /**
     * The filter configuration object we are associated with.  If this value
     * is null, this filter instance is not currently configured.
     */
    private FilterConfig filterConfig = null;
    // --------------------------------------------------------- Public Methods
    /**
     * Take this filter out of service.
     */
    public void destroy() {        this.attribute = null;
        this.filterConfig = null;    }
    /**
     * Time the processing that is performed by all subsequent filters in the
     * current filter stack, including the ultimately invoked servlet.
     *
     * @param request The servlet request we are processing
     * @param result The servlet response we are creating
     * @param chain The filter chain we are processing
     *
     * @exception IOException if an input/output error occurs
     * @exception ServletException if a servlet error occurs
     */
    public void doFilter(ServletRequest request, ServletResponse response,
                         FilterChain chain)
throws IOException, ServletException { // Store ourselves as a request attribute (if requested)
if (attribute != null)
    request.setAttribute(attribute, this); // Time and log the subsequent processing
long startTime = System.currentTimeMillis();
        chain.doFilter(request, response);
long stopTime = System.currentTimeMillis();
filterConfig.getServletContext().log
    (this.toString() + ": " + (stopTime - startTime) +
     " milliseconds");    }
    /**
     * Place this filter into service.
     *
     * @param filterConfig The filter configuration object
     */
    public void init(FilterConfig filterConfig) throws ServletException { this.filterConfig = filterConfig;
        this.attribute = filterConfig.getInitParameter("attribute");    }
    /**
     * Return a String representation of this object.
     */
    public String toString() { if (filterConfig == null)
    return ("InvokerFilter()");
StringBuffer sb = new StringBuffer("InvokerFilter(");
sb.append(filterConfig);
sb.append(")");
return (sb.toString());    }
}

解决方案 »

  1.   

    filter 是什么东东呢?不明白耶..嘿嘿
      

  2.   


    1.用filter解决汉字编码及禁止页面缓存 (不用再在每个页面里去加那几行代码了):
    package beanservlettest;import javax.servlet.*;
    import javax.servlet.http.*;
    import java.io.*;
    import java.util.*;public class servfilter extends HttpServlet implements Filter {
     private FilterConfig filterConfig;
     //Handle the passed-in FilterConfig
     public void init(FilterConfig filterConfig) {
       this.filterConfig = filterConfig;
     }
     //Process the request/response pair
     public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) {
       try {
             request.setCharacterEncoding("GB2312");//设置编码
             ((HttpServletResponse)response).setHeader("Pragma","No-cache");
             ((HttpServletResponse)response).setHeader("Cache-Control","no-cache");
             ((HttpServletResponse)response).setHeader("Expires","0");//禁止缓存
         //自己添加的代码就这上面四行,其它的都是Jbuilder自动生成的:)
         filterChain.doFilter(request, response);
       }
       catch(ServletException sx) {
         filterConfig.getServletContext().log(sx.getMessage());
       }
       catch(IOException iox) {
         filterConfig.getServletContext().log(iox.getMessage());
       }
     }
     //Clean up resources
     public void destroy() {
     }
    }下面是在web.xml里的配置:
    (我的是Jbuilder自动生成的)
     <filter>
       <filter-name>servfilter</filter-name>
       <filter-class>beanservlettest.servfilter</filter-class>
     </filter>
     <filter-mapping>
       <filter-name>servfilter</filter-name>
       <url-pattern>/*</url-pattern>     ///这里表示对整个webapp都有效
     </filter-mapping>