`

java特殊字符过滤器

    博客分类:
  • Java
 
阅读更多
package com.jingdu.common;
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;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class IllegalCharacterFilter implements Filter {
  private String[] characterParams = null;
  private boolean OK=true;

  public void init(FilterConfig config) throws ServletException {
  
//    if(config.getInitParameter("characterParams").length()<1)
//     OK=false;
//    else
//    this.characterParams = config.getInitParameter("characterParams").split(",");
    System.out.println("初始化");
}


  @SuppressWarnings("unchecked")
  public void doFilter(ServletRequest request, ServletResponse response,
      FilterChain arg2) throws IOException, ServletException {
     HttpServletRequest servletrequest = (HttpServletRequest) request;
     HttpServletResponse servletresponse = (HttpServletResponse) response;
     String param = "";
     String paramValue = "";
   
     //设置请求编码格式
     servletresponse.setContentType("text/html");
     servletresponse.setCharacterEncoding("UTF-8");
     servletrequest.setCharacterEncoding("UTF-8");
     java.util.Enumeration params = request.getParameterNames();
     //循环读取参数
     while (params.hasMoreElements()){
       param = (String) params.nextElement(); //获取请求中的参数
       String[] values = servletrequest.getParameterValues(param);//获得每个参数对应的值
    
       for (int i = 0; i < values.length; i++) {

         paramValue = values[i];
       
         //转换目标字符变成对象字符,可以多个。后期扩展特殊字符库用于管理
         paramValue = paramValue.replaceAll("'","");
         paramValue = paramValue.replaceAll("@","");
         paramValue = paramValue.replaceAll("小李","***");
 
        //这里还可以增加,如领导人 自动转义成****,可以从数据库中读取非法关键字。
         values[i] = paramValue;

       }

       //把转义后的参数重新放回request中
       request.setAttribute(param, paramValue);
     }
      //继续向下 执行请求,如果有其他过滤器则执行过滤器
      arg2.doFilter(request, response);
  }

  public void destroy() {
    // TODO Auto-generated method stub
}
}
分享到:
评论

相关推荐

    sql注入Java过滤器

    配置在web.xml中,可以防止SQL注入,可以自己定义一些需要过滤的特殊字符

    java防sql注入攻击过滤器

    java防sql注入攻击过滤器 filter

    java 请求参数过滤拦截

    java 干货,对接口参数进行中的特殊字符,如insert select * % 等进行判断,进行过滤.

    java过滤器对所有参数去除前后空格

    对项目中的所有参数去除前后空格...可以基于此过滤器实现过滤跨站脚本攻击,参数的增加,修改!敏感词汇过滤。实现原理为重写HttpServletRequestWrapper,获取参数的方法。include和 Forwarded 内部转发不在过滤之内。

    java百度编辑器提交过滤标签方法

    百度编辑器提交过滤标签方法

    filterdemo代码

    filter中过滤特殊字符,对页面输入的内容进行过滤

    filter对request请求拦截,对请求参数进行修改

    对request请求进行拦截,对请求...-- 特殊字符过滤 --&gt; &lt;filter-name&gt;sqlFilter &lt;filter-class&gt;weixin.idea.waiting.cq.controller.JsFilter &lt;filter-name&gt;sqlFilter &lt;url-pattern&gt;/* &lt;/filter-mapping&gt;

    Java防止xss攻击附相关文件下载

    首先说一下思路,防止这种类似于注入攻击,就是使用拦截器(Filter)处理特殊字符或过滤特殊字符 今天介绍一个方法,利用覆盖Servlet的getParameter方法达到处理特殊字符的目的来解决(防止)Xss攻击 web.xml,需要的...

    JAVA上百实例源码以及开源项目源代码

     Java波浪文字,一个利用Java处理字符的实例,可以设置运动方向参数,显示文本的字符数组,高速文本颜色,显示字体的 FontMetrics对象,得到Graphics实例,得到Image实例,填充颜色数组数据,初始化颜色数组。...

    JAVA上百实例源码以及开源项目

     Java波浪文字,一个利用Java处理字符的实例,可以设置运动方向参数,显示文本的字符数组,高速文本颜色,显示字体的 FontMetrics对象,得到Graphics实例,得到Image实例,填充颜色数组数据,初始化颜色数组。...

    java开源包11

    jActionScript 是一个使用了 JavaSWF2 的 Flash 解析器和生成器。提供了一个基于对象模型的 ActionScript 字节码,并提供了 ActionScript 字节码统计工具。 Java类重加载工具 JReloader JReloader 是一个用来重新...

    java开源包6

    jActionScript 是一个使用了 JavaSWF2 的 Flash 解析器和生成器。提供了一个基于对象模型的 ActionScript 字节码,并提供了 ActionScript 字节码统计工具。 Java类重加载工具 JReloader JReloader 是一个用来重新...

    java开源包9

    jActionScript 是一个使用了 JavaSWF2 的 Flash 解析器和生成器。提供了一个基于对象模型的 ActionScript 字节码,并提供了 ActionScript 字节码统计工具。 Java类重加载工具 JReloader JReloader 是一个用来重新...

    java开源包101

    jActionScript 是一个使用了 JavaSWF2 的 Flash 解析器和生成器。提供了一个基于对象模型的 ActionScript 字节码,并提供了 ActionScript 字节码统计工具。 Java类重加载工具 JReloader JReloader 是一个用来重新...

    java开源包4

    jActionScript 是一个使用了 JavaSWF2 的 Flash 解析器和生成器。提供了一个基于对象模型的 ActionScript 字节码,并提供了 ActionScript 字节码统计工具。 Java类重加载工具 JReloader JReloader 是一个用来重新...

    java开源包5

    jActionScript 是一个使用了 JavaSWF2 的 Flash 解析器和生成器。提供了一个基于对象模型的 ActionScript 字节码,并提供了 ActionScript 字节码统计工具。 Java类重加载工具 JReloader JReloader 是一个用来重新...

    java开源包8

    jActionScript 是一个使用了 JavaSWF2 的 Flash 解析器和生成器。提供了一个基于对象模型的 ActionScript 字节码,并提供了 ActionScript 字节码统计工具。 Java类重加载工具 JReloader JReloader 是一个用来重新...

    java开源包10

    jActionScript 是一个使用了 JavaSWF2 的 Flash 解析器和生成器。提供了一个基于对象模型的 ActionScript 字节码,并提供了 ActionScript 字节码统计工具。 Java类重加载工具 JReloader JReloader 是一个用来重新...

    java开源包3

    jActionScript 是一个使用了 JavaSWF2 的 Flash 解析器和生成器。提供了一个基于对象模型的 ActionScript 字节码,并提供了 ActionScript 字节码统计工具。 Java类重加载工具 JReloader JReloader 是一个用来重新...

Global site tag (gtag.js) - Google Analytics