java 过滤掉特殊字符以及sql、shell命令

public class StringUtils {
	public static String StringFilter(String str) throws PatternSyntaxException {
		
		// 清除掉所有特殊字符
		str=SqlFilter(str);
		String regEx = "[`~!@#$%^&*()+=|{}':;',//[//].<>/?~!@#¥%……&*()——+|{}【】‘;:”“’。,、?]";
		Pattern p = Pattern.compile(regEx);
		Matcher m = p.matcher(str);
		str= m.replaceAll("").trim();
		return str;
	}
	public static String SqlFilter(String str)
	{
	String[] pattern ={ "select", "insert", "delete", "from", "count\\(", "drop table", "update", "truncate", "asc\\(", "mid\\(", "char\\(", "xp_cmdshell", "exec   master", "netlocalgroup administrators", "net user","CR","LF","BS","or", "and" };
	for (int i = 0; i < pattern.length; i++)
	{
	str = str.replace(pattern[i].toString(), "");
	}
	return str;
	}
	public static void main(String []args)
	{
		  String   str   =   "*or andadCVs*34_a _09_b5*[/435^*&城池()^$$&*).{}+.|.delet)%%*(*.中国}34{45[]12.fd'*&999下面是中文的字符¥……{}【】。,;’“‘”?";      
          System.out.println(str); 
          str=StringFilter(str);
          System.out.println(str); 
	}
	
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值