设为首页收藏本站

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 165|回复: 0

PHP防SQL注入通用代码

[复制链接]
发表于 2013-10-17 08:39:00 | 显示全部楼层 |阅读模式
    SQL注入攻击就其本质而言,它利用的工具是SQL的语法,针对的是应用程序开发者在编程过程中的漏洞,“当攻击者能够操作数据,向应用程序中插入一些SQL语句时,SQL注入攻击就发生了”。实际上,SQL注入攻击是攻击者通过在应用程序中预先定义好的查询语句结尾加上额外的SQL语句元素,欺骗数据库服务器执行非授权的任意查询。SQL注入漏洞是目前互联网最常见也是影响非常广泛的漏洞。

PHP防SQL注入通用代码

  1. <?php

  2. function customError($errno, $errstr, $errfile, $errline)
  3. {
  4. echo "<b>Error number:</b> [$errno],error on line $errline in $errfile<br />";
  5. die();
  6. }
  7. set_error_handler("customError",E_ERROR);
  8. $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)";
  9. $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)";
  10. $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)";
  11. function StopAttack($StrFiltKey,$StrFiltValue,$ArrFiltReq){  

  12. if(is_array($StrFiltValue))
  13. {
  14.     $StrFiltValue=implode($StrFiltValue);
  15. }  
  16. if (preg_match("/".$ArrFiltReq."/is",$StrFiltValue)==1){   
  17.         //slog("<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);
  18.         print "websec notice:Illegal operation!";
  19.         exit();
  20. }      
  21. }  
  22. //$ArrPGC=array_merge($_GET,$_POST,$_COOKIE);
  23. foreach($_GET as $key=>$value){
  24.     StopAttack($key,$value,$getfilter);
  25. }
  26. foreach($_POST as $key=>$value){
  27.     StopAttack($key,$value,$postfilter);
  28. }
  29. foreach($_COOKIE as $key=>$value){
  30.     StopAttack($key,$value,$cookiefilter);
  31. }
  32. if (file_exists('update.php')) {
  33.     echo "请重命名文件update.php,防止黑客利用<br/>";
  34.     die();
  35. }
  36. function slog($logs)
  37. {
  38.   $toppath=$_SERVER["DOCUMENT_ROOT"]."/log.htm";
  39.   $Ts=fopen($toppath,"a+");
  40.   fputs($Ts,$logs."\r\n");
  41.   fclose($Ts);
  42. }
  43. ?>
复制代码

360safe

您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|小黑屋|BC Morning Website ( Best Deal Inc. 001 )  

GMT-8, 2025-12-12 22:30 , Processed in 0.014535 second(s), 16 queries .

Supported by Best Deal Online X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表