日期:2014-05-16  浏览次数:20297 次

jsp参数过滤防注入的解决方法
转自http://voff12.iteye.com/blog
关键字: 反黑
首先注入的类型分为参数数字型注入,参数字浮型注入,搜索框注入三种。
防注入的方法
1)参数过滤。
2)sql语句添加参数用占位符。
public static boolean sql_inj(String str)   
{  
String inj_str = "'|and|exec|insert|select|delete|update|count|*|%|chr|mid|master|truncate|char|declare|;|or|-|+|,";  
String inj_stra[] = split(inj_str,"|");  
for (int i=0 ; i < inj_stra.length ; i++ )  
{  
if (str.indexOf(inj_stra)>=0)  
{  
return true;  
}  
}  
return false;  
}  
 
jsp中调用该函数检查是否包函非法字符  
<%  
if(request.getParameter("userID") != null)  
userID = request.getParameter("userID").trim();  
 
if (StringUtil.sql_inj(userID) || StringUtil.sql_inj(pwd)){  
%>  
<Script Language=javascript>alert('参数中包含非法字符!');history.back(-1);</Script>" ;  
<%  
}else{  
……  
}%>