ホームページ >バックエンド開発 >PHPチュートリアル >PHP アンチ SQL インジェクション コード (360 によって提供)

PHP アンチ SQL インジェクション コード (360 によって提供)

WBOY
WBOYオリジナル
2016-07-25 08:54:541348ブラウズ
  1. /**
  2. * php は SQL インジェクションを防ぎます
  3. * by bbs.it-home.org
  4. */
  5. class sqlsafe {
  6. private $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)";
  7. private $postfilter = "\b(and|or)\b.{1,6 }?(=|>gt;|<|\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)";
  8. private $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)";
  9. /**
  10. *コンストラクター
  11. */
  12. public function __construct() {
  13. foreach($_GET as $key=>$value){$this- >stop Attack($key,$value,$this->getfilter);}
  14. foreach($_POST as $key=>$value){$this->stop Attack($key,$value,$this- >postfilter);}
  15. foreach($_COOKIE as $key=>$value){$this->stop Attack($key,$value,$this->cookiefilter);}
  16. }
  17. /**
  18. * パラメータのチェックとログの書き込み
  19. */
  20. public function stop Attack($StrFiltKey, $StrFiltValue, $ArrFiltReq){
  21. if(is_array($StrFiltValue))$StrFiltValue = implode($StrFiltValue);
  22. if (preg_match("/".$ArrFiltReq.") /is",$StrFiltValue) == 1){
  23. $this->writeslog($_SERVER["REMOTE_ADDR"]." ".strftime("%Y-%m-%d %H:%M:%S ")." ".$_SERVER["PHP_SELF"]." ".$StrFiltKey." ".$StrFiltValue);
  24. showmsg('您提交的パラメータ) ','',0,1);
  25. }
  26. }
  27. /**
  28. *SQL インジェクションログ
  29. */
  30. public function writeslog($log){
  31. $log_path = CACHE_PATH.'logs'.DIRECTORY_SEPARATOR .'sql_log.txt';
  32. $ts = fopen($log_path,"a+");
  33. fputs($ts,$log."rn");
  34. fclose($ts);
  35. }
  36. }
  37. ?>
复制代


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。