php 参数过滤、数据过滤详解
下面通过一段代码给大家介绍php参数过滤
classmysafe{
public$logname;
public$isshwomsg;
function__construct(){
set_error_handler('MyError',E_ALL);
//-----
}
functionMyError($errno,$errstr,$errfile,$errline){
echo"<b>Errornumber:</b>[$errno],erroronline$errlinein$errfile<br/>";
exit;
}
functionwlog($logs){
if(empty($logname)){
$this->logname=$_SERVER["DOCUMENT_ROOT"]."/log.htm";
}
$Ts=fopen($this->logname,"a+");
fputs($Ts,$logs."\r\n");
fclose($Ts);
}
functionshowmsg($msg='',$flag=false){
$this->isshwomsg=empty($this->isshwomsg)?false:true;
if($this->isshwomsg){
echo'<br/>--------------------------------------<br/>';
echo$msg;
echo'<br/>--------------------------------------<br/>';
if($flag)exit;
}
}
functionget_filter(){
$getfilter="'|(and|or)\\b.+?(>|<|=|in|like)|\\/\\*.+?\\*\\/|<\\s*script\\b|\\bEXEC\\b|UNION.+?SELECT|UPDATE.+?SET|INSERT\\s+INTO.+?VALUES|(SELECT|DELETE).+?FROM|(CREATE|ALTER|DROP|TRUNCATE)\\s+(TABLE|DATABASE)";
foreach($_GETas$key=>$value){
$this->StopAttack($key,$value,$getfilter);
}
}
functionpost_filter(){
$postfilter="\\b(and|or)\\b.{1,6}?(=|>|<|\\bin\\b|\\blike\\b)|\\/\\*.+?\\*\\/|<\\s*script\\b|\\bEXEC\\b|UNION.+?SELECT|UPDATE.+?SET|INSERT\\s+INTO.+?VALUES|(SELECT|DELETE).+?FROM|(CREATE|ALTER|DROP|TRUNCATE)\\s+(TABLE|DATABASE)";
foreach($_POSTas$key=>$value){
$this->StopAttack($key,$value,$postfilter);
}
}
functioncookie_filter(){
$cookiefilter="\\b(and|or)\\b.{1,6}?(=|>|<|\\bin\\b|\\blike\\b)|\\/\\*.+?\\*\\/|<\\s*script\\b|\\bEXEC\\b|UNION.+?SELECT|UPDATE.+?SET|INSERT\\s+INTO.+?VALUES|(SELECT|DELETE).+?FROM|(CREATE|ALTER|DROP|TRUNCATE)\\s+(TABLE|DATABASE)";
foreach($_COOKIEas$key=>$value){
$this->StopAttack($key,$value,$cookiefilter);
}
}
//过滤参数
functionStopAttack($StrFiltKey,$StrFiltValue,$ArrFiltReq){
if(is_array($StrFiltValue)){
$StrFiltValue=implode($StrFiltValue);
}
if(preg_match("/".$ArrFiltReq."/is",$StrFiltValue)==1){
$msg="<br><br>操作IP:".$_SERVER["REMOTE_ADDR"]."<br>操作时间:".strftime("%Y-%m-%d%H:%M:%S")."<br>操作页面:".$_SERVER["PHP_SELF"]."<br>提交方式:".$_SERVER["REQUEST_METHOD"]."<br>提交参数:".$StrFiltKey."<br>提交数据:".$StrFiltValue;
$this->wlog($msg);
$this->showmsg($msg);
exit();
}
}
functionfilter_value_for_sql($str){
$str=str_replace("and","",$str);
$str=str_replace("execute","",$str);
$str=str_replace("update","",$str);
$str=str_replace("count","",$str);
$str=str_replace("chr","",$str);
$str=str_replace("mid","",$str);
$str=str_replace("master","",$str);
$str=str_replace("truncate","",$str);
$str=str_replace("char","",$str);
$str=str_replace("declare","",$str);
$str=str_replace("select","",$str);
$str=str_replace("create","",$str);
$str=str_replace("delete","",$str);
$str=str_replace("insert","",$str);
$str=str_replace("'","",$str);
$str=str_replace('"',"",$str);
$str=str_replace("","",$str);
$str=str_replace("or","",$str);
$str=str_replace("=","",$str);
$str=str_replace("","",$str);
return$str;
}
//classend
}
下面给大家介绍下PHP数据过滤
1、php提交数据过滤的基本原则
1)提交变量进数据库时,我们必须使用addslashes()进行过滤,像我们的注入问题,一个addslashes()也就搞定了。其实在涉及到变量取值时,intval()函数对字符串的过滤也是个不错的选择。
2)在php.ini中开启magic_quotes_gpc和magic_quotes_runtime。magic_quotes_gpc可以把get,post,cookie里的引号变为斜杠。magic_quotes_runtime对于进出数据库的数据可以起到格式话的作用。其实,早在以前注入很疯狂时,这个参数就很流行了。
3)在使用系统函数时,必须使用escapeshellarg(),escapeshellcmd()参数去过滤,这样你也就可以放心的使用系统函数。
4)对于跨站,strip_tags(),htmlspecialchars()两个参数都不错,对于用户提交的的带有html和php的标记都将进行转换。比如尖括号"<"就将转化为"<"这样无害的字符。
$new=htmlspecialchars("<ahref='test'>Test</a>",ENT_QUOTES);
strip_tags($text,);
5)对于相关函数的过滤,就像先前的include(),unlink,fopen()等等,只要你把你所要执行操作的变量指定好或者对相关字符过滤严密,我想这样也就无懈可击了。
2、PHP简单的数据过滤
1)入库: trim($str),addslashes($str)
2)出库: stripslashes($str)
3)显示: htmlspecialchars(nl2br($str))