分享JavaWeb中filter过滤器的案例妙用 - 脏话过滤/编码过滤/代码过滤

简介: 分享JavaWeb中filter过滤器的案例妙用 - 脏话过滤/编码过滤/代码过滤

案例1. 利用Servlet的过滤器Filter进行完成脏话过滤

package cn.javabs.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.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
import javax.servlet.http.HttpServletResponse;
 
public class DirtyWordsFilterDemo implements Filter {
 
  public void init(FilterConfig filterConfig) throws ServletException {
 
  }
 
  public void doFilter(ServletRequest req, ServletResponse resp,
      FilterChain chain) throws IOException, ServletException {
    HttpServletRequest request;
    HttpServletResponse response;
    try{
      request = (HttpServletRequest)req;
      response = (HttpServletResponse)resp;
    }catch(Exception e){
      throw new RuntimeException("non-http request");
    }
    DirtyWordHttpServletRequest dwrequest = new DirtyWordHttpServletRequest(request);
    chain.doFilter(dwrequest, response);
    
 
  }
 
  public void destroy() {
 
  }
 
}
class DirtyWordHttpServletRequest extends HttpServletRequestWrapper{
  private String strs[] = {"傻逼","畜生","我去年买了个包"};
  private HttpServletRequest request;
  public DirtyWordHttpServletRequest(HttpServletRequest request){
    super(request);
    this.request = request;
  }
  @Override
  public String getParameter(String name) {
    String value = request.getParameter(name);
    if(value==null)
      return null;
    for(String s:strs){
      if(value.contains(s)){
        value = value.replace(s, "**");
      }
    }
    return value;
  }
  
}

案例2. 利用Servlet的过滤器Filter进行完成Html编码过滤

package cn.javabs.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.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
import javax.servlet.http.HttpServletResponse;
 
public class HtmlFilterDemo implements Filter {
 
  public void init(FilterConfig filterConfig) throws ServletException {
 
  }
 
  public void doFilter(ServletRequest req, ServletResponse resp,
      FilterChain chain) throws IOException, ServletException {
    HttpServletRequest request;
    HttpServletResponse response;
    try{
      request = (HttpServletRequest)req;
      response = (HttpServletResponse)resp;
    }catch(Exception e){
      throw new RuntimeException("non-http request");
    }
    
    HtmlHttpServletRequest hrequest = new HtmlHttpServletRequest(request);
    chain.doFilter(hrequest, response);
 
  }
 
  public void destroy() {
 
  }
 
}
class HtmlHttpServletRequest extends HttpServletRequestWrapper{
  private HttpServletRequest request;
  public HtmlHttpServletRequest(HttpServletRequest request){
    super(request);
    this.request = request;
  }
  @Override
  public String getParameter(String name) {
    String value = request.getParameter(name);
    if(value==null)
      return null;
    value = htmlFilter(value);
    return value;
  }
  private String htmlFilter(String message) {
    if (message == null)
            return (null);
 
        char content[] = new char[message.length()];
        message.getChars(0, message.length(), content, 0);
        StringBuffer result = new StringBuffer(content.length + 50);
        for (int i = 0; i < content.length; i++) {
            switch (content[i]) {
            case '<':
                result.append("&lt;");
                break;
            case '>':
                result.append("&gt;");
                break;
            case '&':
                result.append("&amp;");
                break;
            case '"':
                result.append("&quot;");
                break;
            default:
                result.append(content[i]);
            }
        }
        return (result.toString());
  }
  
}

案例3. 利用Servlet的过滤器Filter进行完成字符编码过滤(Get及Post方式)

  package cn.javabs.filter;
 
  import java.io.IOException;
  import java.io.UnsupportedEncodingException;
 
  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.HttpServletRequestWrapper;
  import javax.servlet.http.HttpServletResponse;
  /**
       * 同时解决GET及POST请求参数和响应输出的编码过滤器
       */
  public class SetAllEncodingFilterDemo implements Filter {
    private FilterConfig filterConfig;
    public void init(FilterConfig filterConfig) throws ServletException {
      this.filterConfig = filterConfig;
    }
 
    public void doFilter(ServletRequest req, ServletResponse resp,
        FilterChain chain) throws IOException, ServletException {
      HttpServletRequest request;
      HttpServletResponse response;
      try{
        request = (HttpServletRequest)req;
        response = (HttpServletResponse)resp;
      }catch(Exception e){
        throw new RuntimeException("non-http request");
      }
      String encoding = "UTF-8";
      String value = filterConfig.getInitParameter("encoding");
      if(value!=null){
        encoding = value;
      }
      
      request.setCharacterEncoding(encoding);//POST请求方式
      response.setContentType("text/html;charset="+encoding);
      MyHttpServletRequest mrequest = new MyHttpServletRequest(request);
      chain.doFilter(mrequest, response);
    }
 
    public void destroy() {
 
    }
 
  }
  class MyHttpServletRequest extends HttpServletRequestWrapper{
    private HttpServletRequest request;
    public MyHttpServletRequest(HttpServletRequest request){
      super(request);
      this.request = request;
    }
    public String getParameter(String name) {
      String value = request.getParameter(name);
      if(value==null)
        return value;
      try {
        if("get".equalsIgnoreCase(request.getMethod()))
          value = new String(value.getBytes("ISO-8859-1"),request.getCharacterEncoding());
      } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
      }
      return value;
    }
    
  }
目录
相关文章
|
1天前
|
前端开发 JavaScript 算法
javaweb(四)——过滤器与监听器
javaweb(四)——过滤器与监听器
|
1天前
|
Java BI Serverless
Java8 Stream深度解析:30个案例3万字助你精通集合筛选、归约、分组与聚合操作
Java8 Stream深度解析:30个案例3万字助你精通集合筛选、归约、分组与聚合操作
8 0
|
1天前
|
SQL 安全 Java
Java中的安全编码实践
Java中的安全编码实践
|
1天前
|
设计模式 算法 Java
Java中的设计模式:实战案例分享
Java中的设计模式:实战案例分享
|
1天前
|
安全 Java API
Java中的函数式编程:简化代码,提升效率
【6月更文挑战第25天】本文将深入探讨Java中函数式编程的概念、原理及其应用。我们将通过具体示例和代码片段来展示如何利用Java 8及以上版本中的Lambda表达式、Stream API等特性来简化代码编写,提高开发效率和程序性能。文章旨在为Java开发者提供一种现代的、更加简洁高效的编程方式。
18 5
|
1天前
|
SQL 存储 安全
Java中的安全编码实践全解析
Java中的安全编码实践全解析
|
2天前
|
SQL 存储 安全
如何在Java中进行安全编码?
如何在Java中进行安全编码?
|
2天前
|
Java 数据库 Spring
解锁 Spring 框架新姿势,让你的 Java 代码更加优雅!
【6月更文挑战第25天】在Spring框架中优化依赖注入、应用AOP和事务管理能提升代码优雅性。例如,使用构造函数注入降低耦合,如将手动创建改为容器管理;通过AOP实现横切关注点,如统一日志记录,避免重复代码;利用`@Transactional`注解简化事务处理,确保数据一致性。这些技巧让代码更简洁、可维护。
|
2天前
|
安全 IDE Java
使用MapStruct和Lombok简化代码
使用MapStruct和Lombok简化代码
17 2
|
1月前
|
Java
使用Java代码打印log日志
使用Java代码打印log日志
270 1