设置各种过滤器

转自:旺仔专栏

 设置不使用缓存的过滤器

功能描述

        将HTTP响应头信息中的缓存参数设置为不进行缓存。

使用方法

        在 java web 项目的 web.xml 文件中添加如下代码。

<!--设置不使用缓存的过滤器配置  开始 -->
<filter> 
 <filter-name>ClearCacheFilter</filter-name> 
 <filter-class>com.hmw.filter.ClearCacheFilter</filter-class> 
</filter> 
  
<filter-mapping> 
 <filter-name>ClearCacheFilter</filter-name> 
 <url-pattern>*.do</url-pattern> 
</filter-mapping> 
<filter-mapping> 
 <filter-name>ClearCacheFilter</filter-name> 
 <url-pattern>*.jsp</url-pattern> 
</filter-mapping> 
<!--设置不使用缓存的过滤器配置  结束 -->

 

 
 

过滤器源码

package com.hmw.filter; 
  
import java.io.IOException; 
  
import javax.servlet.Filter; 
import javax.servlet.FilterChain; 
import javax.servlet.FilterConfig; 
import javax.servlet.ServletException; 
import javax.servlet.ServletRequest; 
import javax.servlet.ServletResponse; 
import javax.servlet.http.HttpServletResponse; 
  
/** 
 * 使浏览器不缓存页面信息的过滤器<BR> 
 * 创建日期:2012-01-10 
 *  
 * @author <A href="mailto:hemingwang0902@126.com">何明旺</A> 
 */
public class ClearCacheFilter implements Filter { 
  
    @Override
    public void init(FilterConfig filterConfig) throws ServletException { 
    } 
  
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, 
            FilterChain filterChain) throws IOException, ServletException { 
        HttpServletResponse httpResponse = (HttpServletResponse) response; 
        httpResponse.setHeader("Cache-Control", "no-cache"); 
        httpResponse.setHeader("Pragma", "no-cache"); 
        httpResponse.setDateHeader("Expires", -1); 
        filterChain.doFilter(request, response); 
    } 
  
    @Override
    public void destroy() { 
    } 
}

 

 通用的用户登陆过滤器

功能描述

        用于检查用户是否登录了系统,如果未登录,则重定向到指的登录页面。

使用方法

        在 java web 项目的 web.xml 文件中添加如下代码,对每个参数都进行了详细的说明。

<!—检查用户是否登录了系统的过滤器配置  开始 --> 
<filter> 
 <filter-name>SessionFilter</filter-name> 
 <filter-class>com.hmw.filter.SessionFilter</filter-class> 
 <init-param> 
     <description>将当前登录的用户的信息保存在 session 中时使用的key,如果没有配置此参数,则该过滤器不起作用</description> 
     <param-name>sessionKey</param-name> 
     <param-value>userInfo</param-value> 
 </init-param> 
 <init-param> 
     <description> 
         如果用户未登录(即在 session 中 key 为 sessionKey 的属性不存在或为空),则将请求重定向到该 url。 
         该 url 不包含web应用的 ContextPath。 
         如果不配置此参数,则在用户未登录系统的情况下,直接重定向到web应用的根路径(/</description> 
     <param-name>redirectUrl</param-name> 
     <param-value>/login.jsp</param-value> 
 </init-param> 
 <init-param> 
     <description> 
         不需要进行拦截的 url 的正则表达式,即:如果当前请求的 url 的 servletPath 能匹配该正则表达式,则直接放行(即使未登录系统)。 
         此参数的值一般为 loginServlet 和 registServlet 等。 
         另外,参数 redirectUrl 的值不用包含在该正则表达式中,因为 redirectUrl 对应的 url 会被自动放行。 
         还有一点需要说明的是,该参数的值不包含web应用的 ContextPath。 
     </description> 
     <param-name>excepUrlRegex</param-name> 
     <!-- 不拦截 /servlets/loginServlet 和 /servlets/registServlet -->
     <param-value>/servlets/(login|regist)Servlet</param-value> 
 </init-param> 
</filter> 
  
<filter-mapping> 
 <filter-name>SessionFilter</filter-name> 
 <url-pattern>/servlets/*</url-pattern> 
</filter-mapping> 
<filter-mapping> 
 <filter-name>SessionFilter</filter-name> 
 <url-pattern>/jsp/*</url-pattern> 
</filter-mapping> 
<!—检查用户是否登录了系统的过滤器配置  结束 --> 

过滤器源码

package com.hmw.filter; 
  
import java.io.IOException; 
import java.net.URLEncoder; 
import java.util.regex.Pattern; 
  
import javax.servlet.Filter; 
import javax.servlet.FilterChain; 
import javax.servlet.FilterConfig; 
import javax.servlet.ServletException; 
import javax.servlet.ServletRequest; 
import javax.servlet.ServletResponse; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
  
import org.apache.commons.lang.StringUtils; 
  
/** 
 * 用于检查用户是否登录了系统的过滤器<br> 
 * 创建日期:2012-01-09 
 * @author <a href="mailto:hemingwang0902@126.com">何明旺</a> 
 */
public class SessionFilter implements Filter { 
  
    /** 要检查的 session 的名称 */
    private String sessionKey; 
      
    /** 需要排除(不拦截)的URL的正则表达式 */
    private Pattern excepUrlPattern; 
      
    /** 检查不通过时,转发的URL */
    private String forwardUrl; 
  
    @Override
    public void init(FilterConfig cfg) throws ServletException { 
        sessionKey = cfg.getInitParameter("sessionKey"); 
  
        String excepUrlRegex = cfg.getInitParameter("excepUrlRegex"); 
        if (!StringUtils.isBlank(excepUrlRegex)) { 
            excepUrlPattern = Pattern.compile(excepUrlRegex); 
        } 
  
        forwardUrl = cfg.getInitParameter("forwardUrl"); 
    } 
  
    @Override
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException { 
        // 如果 sessionKey 为空,则直接放行 
        if (StringUtils.isBlank(sessionKey)) { 
            chain.doFilter(req, res); 
            return; 
        } 
  
//         * 请求 http://127.0.0.1:8080/webApp/home.jsp?&a=1&b=2 时 
//          * request.getRequestURL(): http://127.0.0.1:8080/webApp/home.jsp 
//         * request.getContextPath(): /webApp  
//         * request.getServletPath():/home.jsp 
//         * request.getRequestURI(): /webApp/home.jsp 
//         * request.getQueryString():a=1&b=2 
        HttpServletRequest request = (HttpServletRequest) req; 
        HttpServletResponse response = (HttpServletResponse) res; 
        String servletPath = request.getServletPath(); 
  
        // 如果请求的路径与forwardUrl相同,或请求的路径是排除的URL时,则直接放行 
        if (servletPath.equals(forwardUrl) || excepUrlPattern.matcher(servletPath).matches()) { 
            chain.doFilter(req, res); 
            return; 
        } 
  
        Object sessionObj = request.getSession().getAttribute(sessionKey); 
        // 如果Session为空,则跳转到指定页面 
        if (sessionObj == null) { 
            String contextPath = request.getContextPath(); 
            String redirect = servletPath + "?" + StringUtils.defaultString(request.getQueryString()); 
            /* 
             * login.jsp 的 <form> 表单中新增一个隐藏表单域: 
             * <input type="hidden" name="redirect" value="${param.redirect }"> 
             *  
             *  LoginServlet.java 的 service 的方法中新增如下代码: 
             *  String redirect = request.getParamter("redirect"); 
             *  if(loginSuccess){ 
             *      if(redirect == null || redirect.length() == 0){ 
             *          // 跳转到项目主页(home.jsp) 
             *      }else{ 
             *          // 跳转到登录前访问的页面(java.net.URLDecoder.decode(s, "UTF-8")) 
             *      } 
             *  }  
             */
            response.sendRedirect(contextPath + StringUtils.defaultIfEmpty(forwardUrl, "/") 
                            + "?redirect=" + URLEncoder.encode(redirect, "UTF-8")); 
        } else { 
            chain.doFilter(req, res); 
        } 
    } 
  
    @Override
    public void destroy() { 
    } 
}

 

 设置站点黑名单的过滤器

功能描述

        不允许从禁用的站点(IP)访问当前应用,也不允许从禁用的站点链接到当前应用。
        为了简单起见,设置禁用站点时,暂不支持使用通配符。只是抛砖引玉了。
        比如:禁止其他的网站引用本站的图片资源,只需在此基础上稍作修改即可。

使用方法

        在 java web 项目的 web.xml 文件中添加如下代码。

<!--设置站点黑名单的过滤器配置  开始 -->
<filter> 
 <filter-name>BannedAccessFilter</filter-name> 
 <filter-class>com.hmw.filter.BannedAccessFilter</filter-class> 
 <init-param> 
     <description>需要禁用的站点,一个站点占用一行</description> 
     <param-name>bannedSites</param-name> 
     <param-value> 
         192.168.1.101 
         192.168.1.102 
         www.csdn.net 
     </param-value> 
 </init-param> 
</filter> 
  
<filter-mapping> 
 <filter-name>BannedAccessFilter</filter-name> 
 <url-pattern>/*</url-pattern> 
</filter-mapping> 
<!--设置站点黑名单的过滤器配置  结束 --> 

过滤器源码

package com.hmw.filter; 
  
import java.io.IOException; 
import java.io.PrintWriter; 
import java.net.MalformedURLException; 
import java.net.URL; 
import java.util.HashSet; 
import java.util.StringTokenizer; 
  
import javax.servlet.Filter; 
import javax.servlet.FilterChain; 
import javax.servlet.FilterConfig; 
import javax.servlet.ServletException; 
import javax.servlet.ServletRequest; 
import javax.servlet.ServletResponse; 
import javax.servlet.http.HttpServletRequest; 
  
import org.apache.commons.lang3.StringUtils; 
import org.apache.log4j.Logger; 
  
/** 
 * 设置禁用站点(黑名单)的过滤器 
 * @author <A href="mailto:hemingwang0902@126.com">何明旺</A> 
 */
public class BannedAccessFilter implements Filter { 
    static final Logger logger = Logger.getLogger(BannedAccessFilter.class); 
      
    private HashSet bannedSiteTable; 
      
    /** 
     * 将配置的禁用站点列表初始化到一个 HashSet 中 
     */
    @Override
    public void init(FilterConfig config) throws ServletException { 
        bannedSiteTable = new HashSet(); 
        String bannedSites = config.getInitParameter("bannedSites"); 
        // Default token set: white space. 
        StringTokenizer tok = new StringTokenizer(bannedSites); 
        while (tok.hasMoreTokens()) { 
            String bannedSite = tok.nextToken(); 
            bannedSiteTable.add(bannedSite); 
            logger.info("Banned " + bannedSite); 
        } 
    } 
      
    /** 
     * 如果请求来自被禁用的站点,或是从被禁用的站点链接过来的,则拒绝访问。 
     */
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException { 
        logger.debug("BannedAccessFilter: Filtering the Request..."); 
          
        HttpServletRequest req = (HttpServletRequest) request; 
        String requestingHost = req.getRemoteHost(); 
        String referringHost = getReferringHost(req.getHeader("Referer")); 
          
        String bannedSite = null; 
        boolean isBanned = false; 
        if (bannedSiteTable.contains(requestingHost)) { 
            bannedSite = requestingHost; 
            isBanned = true; 
        } else if (bannedSiteTable.contains(referringHost)) { 
            bannedSite = referringHost; 
            isBanned = true; 
        } 
          
        if (isBanned) { 
            showWarning(response, bannedSite); 
        } else { 
            chain.doFilter(request, response); 
        } 
          
        logger.debug("BannedAccessFilter: Filtering the Response..."); 
    } 
  
    @Override
    public void destroy() { 
    } 
  
    /** 
     * 根据 URL 链接地址,取得该链接地址所在的站点 
     * @param refererringURLString URL链接地址 
     * @return 该 URL 链接地址所在的站点,如果传入的参数不是一个符合URL规范的字符串,则返回 <CODE>null</CODE> 
     */
    private String getReferringHost(String refererringURLString) { 
        if(StringUtils.isBlank(refererringURLString)) 
            return null; 
          
        try { 
            URL referringURL = new URL(refererringURLString); 
            return referringURL.getHost(); 
        } catch (MalformedURLException mue) { // Malformed 
            return null; 
        } 
    } 
  
    /** 
     * 如果用户是从禁用站点访问的该应用,或是从禁用站点链接过来的,则调用此方法将警告信息展现给用户。 
     * @param response HTTP请求响应对象 
     * @param bannedSite 禁止的站点 
     * @throws ServletException 
     * @throws IOException 
     * @author <A href="mailto:hemw@mochasoft.com.cn">何明旺</A> 
     */
    private void showWarning(ServletResponse response, String bannedSite) throws ServletException, IOException { 
        String htmlCode  = ""; 
        htmlCode += "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">"; 
        htmlCode += "<html xmlns=\"http://www.w3.org/1999/xhtml\">"; 
        htmlCode += "  <head>"; 
        htmlCode += "      <meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\" />"; 
        htmlCode += "      <title>禁止访问</title>"; 
        htmlCode += "  </head>"; 
        htmlCode += "  <body>"; 
        htmlCode += "      <h1>禁止访问</h1>"; 
        htmlCode += "      <p>对不起,您无法访问该资源,因为您的站点已经被列入我们的黑名单!</p>"; 
        htmlCode += "      <p>您的站点是:<strong>" + bannedSite + "</strong></p>"; 
        htmlCode += "  </body>"; 
        htmlCode += "</html>"; 
  
        response.setContentType("text/html"); 
        PrintWriter out = null; 
        try{ 
            out = response.getWriter(); 
            out.println(htmlCode); 
        }finally{ 
              if(out != null){ 
                out.flush(); 
                out.close(); 
              } 
        } 
          
        /* 
         * 也可以使用下面的方法直接转发或重定向到指定的警告页面 
         * 转发: 
         *     ((HttpServletRequest)request).getRequestDispatcher("/warn.html").forward(request, response); 
         * 重定向: 
         *     ((HttpServletResponse)response).sendRedirect("webAppContext/warn.html"); 
         */
    } 
} 

 将响应数据进行压缩处理的过滤器

功能描述

        如果浏览器支持 gzip 压缩格式的数据,则将响应的数据使用 gzip 压缩后再输出。

使用方法

        在 java web 项目的 web.xml 文件中添加如下代码。

<!--压缩过滤器的配置  开始 -->
 <filter> 
 <filter-name>CompressionFilter</filter-name> 
 <filter-class>com.hmw.filter.CompressionFilter</filter-class> 
 </filter> 
   
 <filter-mapping> 
 <filter-name>CompressionFilter</filter-name> 
   <servlet-name>/LongServlet</servlet-name> 
 </filter-mapping> 
<!--压缩过滤器的配置  结束 --> 

过滤器源码

CompressionFilter.java
?package com.hmw.filter; 
  
import java.io.ByteArrayOutputStream; 
import java.io.IOException; 
import java.io.OutputStream; 
import java.io.OutputStreamWriter; 
import java.util.zip.GZIPOutputStream; 
  
import javax.servlet.Filter; 
import javax.servlet.FilterChain; 
import javax.servlet.FilterConfig; 
import javax.servlet.ServletException; 
import javax.servlet.ServletRequest; 
import javax.servlet.ServletResponse; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
  
/** 
 * 压缩过滤器 <BR> 
 * 如果浏览器支持 gzip 压缩格式的数据,则将响应的数据使用 gzip 压缩后再输出。 
 *  
 * @author <A href="mailto:hemingwang0902@126.com">何明旺</A> 
 */
public class CompressionFilter implements Filter { 
  
    @Override
    public void init(FilterConfig config) throws ServletException { 
    } 
  
    /** 
     * 如果浏览器不支持 gzip 压缩,则不做直接放行(不做压缩处理)<BR> 
     * 反之,将HTTP响应头的编码设置为 <CODE>gzip</CODE>,然后将响应数据使用 gzip 进行压缩处理。 
     */
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, 
            FilterChain chain) throws ServletException, IOException { 
        HttpServletRequest req = (HttpServletRequest) request; 
        HttpServletResponse res = (HttpServletResponse) response; 
  
        if (!isGzipSupported(req)) { // Invoke resource normally. 
            chain.doFilter(req, res); 
            return; 
        } 
  
        // 将响应头信息中的内容编码设置为 gzip 
        res.setHeader("Content-Encoding", "gzip"); 
          
        // 调用资源,使用 CharArrayWrapper 包装输出 
        CharArrayWrapper responseWrapper = new CharArrayWrapper(res); 
        chain.doFilter(req, responseWrapper); 
        // 取得存放输出数据的 char 型数组 
        char[] responseChars = responseWrapper.toCharArray(); 
          
        // 将响应数据压缩后存入一个 byte 型的数组,然后输出到 
        ByteArrayOutputStream byteStream = new ByteArrayOutputStream(); 
        GZIPOutputStream zipOut = new GZIPOutputStream(byteStream); 
        OutputStreamWriter tempOut = new OutputStreamWriter(zipOut); 
        // 将原来的响应数据压缩后写入二字节输出流 
        tempOut.write(responseChars); 
        // 关闭输出流 
        tempOut.close(); 
  
        // 更新响应头信息中 Content-Length 的值。 
        res.setContentLength(byteStream.size()); 
        // 将压缩后的数据发送至客户端 
        OutputStream realOut = res.getOutputStream(); 
        byteStream.writeTo(realOut); 
    } 
  
    @Override
    public void destroy() { 
    } 
  
    /** 
     * 检测浏览器是否支持 Gzip 压缩 
     *  
     * @param req HTTP 请求对象 
     * @return 如果浏览器支持 Gzip 压缩,则返回 true,反之,则返回 false 
     */
    private boolean isGzipSupported(HttpServletRequest req) { 
        String browserEncodings = req.getHeader("Accept-Encoding"); 
        return ((browserEncodings != null) && (browserEncodings.indexOf("gzip") != -1)); 
    } 
} 
CharArrayWrapper.java
?package com.hmw.filter; 
  
import java.io.CharArrayWriter; 
import java.io.PrintWriter; 
  
import javax.servlet.http.HttpServletResponse; 
import javax.servlet.http.HttpServletResponseWrapper; 
  
/** 
 * A response wrapper that takes everything the client would normally output and 
 * saves it in one big character array. 
 */
public class CharArrayWrapper extends HttpServletResponseWrapper { 
    private CharArrayWriter charWriter; 
  
    /** 
     * Initializes wrapper. 
     * <P> 
     * First, this constructor calls the parent constructor. That call is 
     * crucial so that the response is stored and thus setHeader, *setStatus, 
     * addCookie, and so forth work normally. 
     * <P> 
     * Second, this constructor creates a CharArrayWriter that will be used to 
     * accumulate the response. 
     */
    public CharArrayWrapper(HttpServletResponse response) { 
        super(response); 
        charWriter = new CharArrayWriter(); 
    } 
  
    /** 
     * When servlets or JSP pages ask for the Writer, don't give them the real 
     * one. Instead, give them a version that writes into the character array. 
     * The filter needs to send the contents of the array to the client (perhaps 
     * after modifying it). 
     */
    @Override
    public PrintWriter getWriter() { 
        return new PrintWriter(charWriter); 
    } 
  
    /** 
     * Get a String representation of the entire buffer. 
     * <P> 
     * Be sure <B>not</B> to call this method multiple times on the same 
     * wrapper. The API for CharArrayWriter does not guarantee that it 
     * "remembers" the previous value, so the call is likely to make a new 
     * String every time. 
     */
    @Override
    public String toString() { 
        return charWriter.toString(); 
    } 
  
    /** Get the underlying character array. */
    public char[] toCharArray() { 
        return charWriter.toCharArray(); 
    } 
} 

 

 替换禁用语(指定关键字)

功能描述

        将请求响应中所有的禁用关键字替换掉之后再输出。

使用方法

        在 java web 项目的 web.xml 文件中添加如下代码。

<!--替换关键字的过滤器配置  开始 -->
 <filter> 
 <filter-name>StopWordsFilter</filter-name> 
 <filter-class>com.hmw.filter.StopWordsFilter</filter-class> 
 <init-param> 
     <description>需要禁用的关键字,一个关键字占一行</description> 
     <param-name>keys</param-name> 
     <param-value> 
       QQ 
       百度 
       七一五 
     </param-value> 
 </init-param> 
 </filter> 
   
 <filter-mapping> 
 <filter-name>StopWordsFilter</filter-name> 
   <servlet-name>*.jsp</servlet-name> 
 </filter-mapping> 
<!--替换关键字的过滤器  结束 --> 

过滤器源码

ReplaceKeyWordFilter.java
?package com.hmw.filter; 
  
import java.io.IOException; 
import java.io.PrintWriter; 
import java.util.HashSet; 
import java.util.Iterator; 
import java.util.Set; 
import java.util.StringTokenizer; 
  
import javax.servlet.Filter; 
import javax.servlet.FilterChain; 
import javax.servlet.FilterConfig; 
import javax.servlet.ServletException; 
import javax.servlet.ServletRequest; 
import javax.servlet.ServletResponse; 
import javax.servlet.http.HttpServletResponse; 
  
/** 
 * 替换关键字的滤器 <BR> 
 *  
 * @author <A href="mailto:hemingwang0902@126.com">何明旺</A> 
 */
public class StopWordsFilter implements Filter { 
    private Set keyWords = new HashSet(); 
  
    /** 
     * 将需要进行替换的关键字添加到一个定义好的 Set 中 
     */
    @Override
    public void init(FilterConfig config) throws ServletException { 
        String keys =  config.getInitParameter("keys"); 
        StringTokenizer tokenizer = new StringTokenizer(keys); 
        String token = null; 
        while (tokenizer.hasMoreTokens()) { 
            token = tokenizer.nextToken(); 
            if(token != null && token.length() > 0){ 
                keyWords.add(tokenizer.nextToken()); 
            } 
        } 
    } 
  
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, 
            FilterChain chain) throws ServletException, IOException { 
        CharArrayWrapper responseWrapper = new CharArrayWrapper( 
                (HttpServletResponse) response); 
        // 调用请求资源(使用自己包装的 responseWrapper) 
        chain.doFilter(request, responseWrapper); 
        // 取得响应字符串 
        String responseString = responseWrapper.toString(); 
        // 将需要替换的关键字用“**”替换掉 
        Iterator iter = keyWords.iterator(); 
        while (iter.hasNext()) { 
            responseString = replace(responseString, iter.next(), "**"); 
        } 
          
        // 修改响应头信息中的 Content-Length 
        response.setContentLength(responseString.length()); 
        PrintWriter out = response.getWriter(); 
        out.write(responseString); 
    } 
  
    @Override
    public void destroy() { 
    } 
  
    /** 
     * 将字符串中的所有的指定子字符串替换掉 
     * @param mainString 需要进行替换的字符串 
     * @param orig 需要被替换的子串 
     * @param replacement 替换后的新串 
     * @return 返回替换后的字符串 
     */
    public static String replace(String mainString, String orig, String replacement) { 
        String result = ""; 
        int oldIndex = 0; 
        int index = 0; 
        int origLength = orig.length(); 
        while ((index = mainString.indexOf(orig, oldIndex)) != -1) { 
            result = result + mainString.substring(oldIndex, index) + replacement; 
            oldIndex = index + origLength; 
        } 
        result = result + mainString.substring(oldIndex); 
        return result; 
    } 
} 
CharArrayWrapper.java
?package com.hmw.filter; 
  
import java.io.CharArrayWriter; 
import java.io.PrintWriter; 
  
import javax.servlet.http.HttpServletResponse; 
import javax.servlet.http.HttpServletResponseWrapper; 
  
/** 
 * A response wrapper that takes everything the client would normally output and 
 * saves it in one big character array. 
 */
public class CharArrayWrapper extends HttpServletResponseWrapper { 
    private CharArrayWriter charWriter; 
  
    /** 
     * Initializes wrapper. 
     * <P> 
     * First, this constructor calls the parent constructor. That call is 
     * crucial so that the response is stored and thus setHeader, *setStatus, 
     * addCookie, and so forth work normally. 
     * <P> 
     * Second, this constructor creates a CharArrayWriter that will be used to 
     * accumulate the response. 
     */
    public CharArrayWrapper(HttpServletResponse response) { 
        super(response); 
        charWriter = new CharArrayWriter(); 
    } 
  
    /** 
     * When servlets or JSP pages ask for the Writer, don't give them the real 
     * one. Instead, give them a version that writes into the character array. 
     * The filter needs to send the contents of the array to the client (perhaps 
     * after modifying it). 
     */
    @Override
    public PrintWriter getWriter() { 
        return new PrintWriter(charWriter); 
    } 
  
    /** 
     * Get a String representation of the entire buffer. 
     * <P> 
     * Be sure <B>not</B> to call this method multiple times on the same 
     * wrapper. The API for CharArrayWriter does not guarantee that it 
     * "remembers" the previous value, so the call is likely to make a new 
     * String every time. 
     */
    @Override
    public String toString() { 
        return charWriter.toString(); 
    } 
  
    /** Get the underlying character array. */
    public char[] toCharArray() { 
        return charWriter.toCharArray(); 
    } 
} 

 

 

 

 

转载于:https://www.cnblogs.com/shangguan/p/3169909.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值