热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PHP防注入函数代码总结

在php中防注入一般会写一个全局文件用来过滤特殊的字符串,本文章来总结了各种各样的php防注入函数代码,同时还可防sql注入大家可参考.为了安全,我们常用到下面的函数来过滤一些传递过来的非法字符,P...
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
当前位置:首页 > PHP教程 > php函数 > 列表
PHP防注入函数代码总结
发布: 来源:  添加日期:2014-08-22 14:19:17 浏览: 评论:0 

在php中防注入一般会写一个全局文件用来过滤特殊的字符串,本文章来总结了各种各样的php防注入函数代码,同时还可防sql注入大家可参考.

为了安全,我们常用到下面的函数来过滤一些传递过来的非法字符,PHP防注入函数,代码如下:

  1. //要过滤的非法字符 
  2. $ArrFiltrate=array(“‘”,”;”,”union”,”select”,”delete”,”‘”,”or”,”and”,”=”); 
  3. //出错后要跳转的url,不填则默认前一页 
  4. $StrGoUrl=”"; 
  5. //是否存在数组中的值 
  6. function FunStringExist($StrFiltrate,$ArrFiltrate){ 
  7. foreach ($ArrFiltrate as $key=>$value){ 
  8. if (eregi($value,$StrFiltrate)){ 
  9. return true; 
  10. return false; 
  11. //合并$_POST 和 $_GET 
  12. if(function_exists(array_merge)){ 
  13. $ArrPostAndGet=array_merge($HTTP_POST_VARS,$HTTP_GET_VARS); 
  14. }else
  15. foreach($HTTP_POST_VARS as $key=>$value){ 
  16. $ArrPostAndGet[]=$value
  17. foreach($HTTP_GET_VARS as $key=>$value){ 
  18. $ArrPostAndGet[]=$value
  19. //验证开始 
  20. foreach($ArrPostAndGet as $key=>$value){ 
  21. if (FunStringExist($value,$ArrFiltrate)){ 
  22. if (emptyempty($StrGoUrl)){ 
  23. echo “”; 
  24. }else
  25. echo “”; 
  26. exit

再看一个实例与上面差不多,这个是dz论坛使用的方法,代码如下:

  1. $magic_quotes_gpc = get_magic_quotes_gpc();  
  2. @extract(daddslashes($_COOKIE));  
  3. @extract(daddslashes($_POST));  
  4. @extract(daddslashes($_GET));  
  5. if(!$magic_quotes_gpc) {  
  6. $_FILES = daddslashes($_FILES);  
  7. function daddslashes($string$force = 0) {  
  8. if(!$GLOBALS['magic_quotes_gpc'] || $force) {  
  9. if(is_array($string)) {  
  10. foreach($string as $key => $val) {  
  11. $string[$key] = daddslashes($val$force);  
  12. //开源代码phpfensi.com 
  13. else {  
  14. $string = addslashes($string);  
  15. }  
  16. }  
  17. return $string;  

最后发一加强版的,代码如下:

  1. $field = explode(','$data); 
  2. array_walk($fieldarray($this'add_special_char')); 
  3. $data = implode(','$field); 
  4. /** 
  5.  * 对字段两边加反引号,以保证数据库安全 
  6.  * @param $value 数组值 
  7.  */ 
  8. public function add_special_char(&$value) { 
  9.  if('*' == $value || false !== strpos($value'(') || false !== strpos($value'.') || false !== strpos ( $value'`')) { 
  10.   //不处理包含* 或者 使用了sql方法。 
  11.  } else { 
  12.   $value = '`'.trim($value).'`'
  13.  } 
  14.  return $value
  15. function str_filter($str) { 
  16.  $str = htmlspecialchars ( $str ); 
  17.  if (! get_magic_quotes_gpc ()) { 
  18.   $str = addslashes ( $str ); 
  19.  } 
  20.  //过滤危险字符 
  21.  return preg_replace ( "/["'=]|(and)|(or)|(create)|(update)|(alter)|(delete)|(insert)|(load_file)|(outfile)|(count)|(%20)|(char)/i", "", $str ); 
  22. /* 
  23. 函数名称:str_check() 
  24. 函数作用:对提交的字符串进行过滤 
  25. 参  数:$var: 要处理的字符串 
  26. 返 回 值:返回过滤后的字符串 
  27. */ 
  28. function str_check($str) { 
  29.  if (! get_magic_quotes_gpc ()) { // 判断magic_quotes_gpc是否打开 
  30.   $str = addslashes ( $str ); // 进行过滤 
  31.  } 
  32.  $str = str_replace ( "_""_"$str ); // 把 '_'过滤掉 
  33.  $str = str_replace ( "%""%"$str ); // 把 '%'过滤掉 
  34.  return $str
  35.  
  36. /* 
  37. 函数名称:post_check() 
  38. 函数作用:对提交的编辑内容进行处理 
  39. 参  数:$post: 要提交的内容 
  40. 返 回 值:$post: 返回过滤后的内容 
  41. */ 
  42. function post_check($post) { 
  43.  if (! get_magic_quotes_gpc ()) { // 判断magic_quotes_gpc是否为打开 
  44.   $post = addslashes ( $post ); // 进行magic_quotes_gpc没有打开的情况对提交数据的过滤 
  45.  } 
  46.  $post = str_replace ( "_""_"$post ); // 把 '_'过滤掉 
  47.  $post = str_replace ( "%""%"$post ); // 把 '%'过滤掉 
  48.  $post = nl2br ( $post ); // 回车转换 
  49.  $post = htmlspecialchars ( $post ); // html标记转换 
  50.  return $post
  51. /* 
  52. 函数名称:inject_check() 
  53. 函数作用:检测提交的值是不是含有SQL注射的字符,防止注射,保护服务器安全 
  54. 参  数:$sql_str: 提交的变量 
  55. 返 回 值:返回检测结果,ture or false 
  56. */ 
  57. function inject_check($sql_str) { 
  58.  return eregi('select|insert|and|or|update|delete|'|/*|*|../|./|union|into|load_file|outfile', $sql_str);     // 进行过滤 
  59. } 
  60.  
  61. /* 
  62. 函数名称:verify_id() 
  63. 函数作用:校验提交的ID类值是否合法 
  64. 参  数:$id: 提交的ID值 
  65. 返 回 值:返回处理后的ID 
  66. */ 
  67. function verify_id($id=null) { 
  68.  if (!$id) { exit('没有提交参数!'); }     // 是否为空判断 
  69.  elseif (inject_check($id)) { exit('提交的参数非法!'); }     // 注射判断 
  70.  elseif (!is_numeric($id)) { exit('提交的参数非法!'); }     // 数字判断 
  71.  $id = intval($id);     // 整型化 
  72.  
  73.  return   $id
  74.  
  75. // $rptype = 0 表示仅替换 html标记 
  76. // $rptype = 1 表示替换 html标记同时去除连续空白字符 
  77. // $rptype = 2 表示替换 html标记同时去除所有空白字符 
  78. // $rptype = -1 表示仅替换 html危险的标记 
  79. function HtmlReplace($str$rptype = 0) { 
  80.  $str = stripslashes ( $str ); 
  81.  if ($rptype == 0) { 
  82.   $str = htmlspecialchars ( $str ); 
  83.  } else if ($rptype == 1) { 
  84.   $str = htmlspecialchars ( $str ); 
  85.   $str = str_replace ( " "' '$str ); 
  86.   $str = ereg_replace ( "[rnt ]{1,}"' '$str ); 
  87.  } else if ($rptype == 2) { 
  88.   $str = htmlspecialchars ( $str ); 
  89.   $str = str_replace ( " "''$str ); 
  90.   $str = ereg_replace ( "[rnt ]"''$str ); 
  91.  } else { 
  92.   $str = ereg_replace ( "[rnt ]{1,}"' '$str ); 
  93.   $str = eregi_replace ( 'script''script'$str ); 
  94.   $str = eregi_replace ( "<[/]{0,1}(link|meta|ifr|fra)[^>]*>"&#39;&#39;$str ); 
  95.  } 
  96.  return addslashes ( $str ); 
  97. //递归ddslashes 
  98. function daddslashes($string$force = 0, $strip = FALSE) { 
  99.  if (! get_magic_quotes_gpc () || $force) { 
  100.   if (is_array ( $string )) { 
  101.    foreach ( $string as $key => $val ) { 
  102.     $string [$key] = daddslashes ( $val$force ); 
  103.    } 
  104.   } else { 
  105.    $string = addslashes ( $strip ? stripslashes ( $string ) : $string ); 
  106.   } 
  107.  } 
  108.  return $string
  109.  
  110. //递归stripslashes 
  111. function dstripslashes($string) { 
  112.  if (is_array ( $string )) { 
  113.   foreach ( $string as $key => $val ) { 
  114.    $string [$key] = $this->dstripslashes ( $val ); 
  115.   } 
  116.  } else { 
  117.   $string = stripslashes ( $string ); 
  118.  } 
  119.  return $string
  120. /** 
  121.  * 安全过滤函数 
  122.  * @param $string 要过滤的字符串 
  123.  * @return string 返回处理过的字符串 
  124.  */ 
  125. function safe_replace($string) { 
  126.  $string = str_replace(&#39;%20&#39;,&#39;&#39;,$string); 
  127.  $string = str_replace(&#39;%27&#39;,&#39;&#39;,$string); 
  128.  $string = str_replace(&#39;%2527&#39;,&#39;&#39;,$string); 
  129.  $string = str_replace(&#39;*&#39;,&#39;&#39;,$string); 
  130.  $string = str_replace(&#39;"&#39;,&#39;"&#39;,$string); 
  131.  $string = str_replace("&#39;",&#39;&#39;,$string); 
  132.  $string = str_replace(&#39;"&#39;,&#39;&#39;,$string); 
  133.  $string = str_replace(&#39;;&#39;,&#39;&#39;,$string); 
  134.  $string = str_replace(&#39;<&#39;,&#39;<&#39;,$string); 
  135.  $string = str_replace(&#39;>&#39;,&#39;>&#39;,$string); 
  136.  $string = str_replace("{",&#39;&#39;,$string); 
  137.  $string = str_replace(&#39;}&#39;,&#39;&#39;,$string); 
  138.  return $string
  139.  
  140. /** 
  141.  * 使用htmlspecialchars处理字符串或数组 
  142.  * @param $obj 需要处理的字符串或数组 
  143.  * @return mixed 返回经htmlspecialchars处理过的字符串或数组 
  144.  */ 
  145. function new_htmlspecialchars($string) { 
  146.  if(!is_array($string)) 
  147.  return htmlspecialchars($string); 
  148.  foreach($string as $key => $val
  149.  $string[$key] = new_htmlspecialchars($val); 
  150.  return $string
  151.  
  152. //处理禁用HTML但允许换行的内容 
  153. function TrimMsg($msg) { 
  154.  $msg = trim ( stripslashes ( $msg ) ); 
  155.  $msg = nl2br ( htmlspecialchars ( $msg ) ); 
  156.  $msg = str_replace ( "  ""  "$msg ); 
  157.  return addslashes ( $msg ); 
  158. ?> 

推荐阅读
  • linux json 写sql注入,sql注入之json注入(php代码)
    环境phpstudyphp服务端代码security数据库中的users表中的username,password字段用户名adminJSON服务端代码大家实际测试中注 ... [详细]
  • Git是一个开源的分布式版本控制系统,用以有效、高速的处理从很小到非常大的项目版本管理,现在在企业中的使用率也是很广的。git是一个分布式的版本控制系统,不像以前的svn,svn是 ... [详细]
  • 安全3AAuthentication:认证Authorzation:授权Accouting|Audition:审计用户管理用户:UID:0,不一定是root,root的uid非0时 ... [详细]
  • Java工作流引擎关于数据加密流程(MD5数据加密防篡改)
    关键字:驰骋工作流程快速开发平台工作流程管理系统工作流引擎asp.net工作流引擎java工作流引擎.开发者表单拖拽式表单工作流系统流程数据加密md5数据保密流程数据防篡改软加密适 ... [详细]
  • 阿里云大数据计算服务MaxCompute (原名 ODPS)
     MaxCompute是阿里EB级计算平台,经过十年磨砺,它成为阿里巴巴集团数据中台的计算核心和阿里云大数据的基础服务。去年MaxCompute做了哪些工作,这些工作背后的原因是什 ... [详细]
  • nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 两种方式实现Flink异步IO查询Mysql
    如官网所描述的Flink支持两种方式实现异步IO查询外部系统http ... [详细]
  • 导读:很多朋友问到关于入门学什么php框架简单的相关问题,本文编程笔记就来为大家做个详细解答,供大家参考,希望对大家有所帮助!一起来看看吧!本文目录一览: ... [详细]
  • 接上文http:blog.itpub.net29254281viewspace-1318239领导让开发同学鼓捣一个可配置化的后台.又回到了原来的问题如果要灵活,很多参数要 ... [详细]
  • 吴恩达“机器学习”——学习笔记二
    定义一些名词欠拟合(underfitting):数据中的某些成分未被捕获到,比如拟合结果是二次函数,结果才只拟合出了一次函数。过拟合(overfitting):使用过量的特征集合, ... [详细]
  • nacos的github的链接:https:github.comalibabanacosreleasestag1.4.1nacos的ZIP的链接:htt ... [详细]
  • 利用ipv6技术,废旧笔记本变成server
    如果你家的路由器已经get到了ipv6地址,并且你家的电脑也获取了有效的ipv6地址,在广域网的设备可以访问到。那恭喜你,再配合我这个dd ... [详细]
  • phpmysql一键安装包,Mysql安装包
    本文目录一览:1、哪里有PHPMySQLDatabaseApacheServer一 ... [详细]
  • Linux文件目录和权限
    Linux文件目录和权限前言:Linux一般将文件可存取的身份分为三个类别,分别是ownergroupothers,根据权限划分,每个目录都可以拥有相对身份的-rwx[可读可写可执 ... [详细]
  • mysql mmm搭建_搭建mysqlmmm高可用MySQL集群
    实验需求:配置mysql-mmm,实现mysql的高可用MySQL-MMM实现MySQL高可用http:www.linuxidc.comLinux201 ... [详细]
author-avatar
手机用户2502883445
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有