当前位置:首页 > PHP教程 > php应用 > 列表

php简单实现sql防注入的方法

发布:smiling 来源: PHP粉丝网  添加日期:2019-08-22 11:41:52 浏览: 评论:0 

本文实例讲述了php简单实现sql防注入的方法。分享给大家供大家参考,具体如下:

这里没有太多的过滤,主要是针对php和mysql的组合。

一般性的防注入,只要使用php的 addslashes 函数就可以了。

以下是一段copy来的代码:

PHP代码:

  1. $_POST = sql_injection($_POST); 
  2.  
  3. $_GET = sql_injection($_GET); 
  4.  
  5. function sql_injection($content
  6.  
  7.  
  8. if (!get_magic_quotes_gpc()) { 
  9.  
  10. if (is_array($content)) { 
  11.  
  12. foreach ($content as $key=>$value) { 
  13.  
  14. $content[$key] = addslashes($value); 
  15.  
  16. //phpfensi.com 
  17. else { 
  18.  
  19. addslashes($content); 
  20.  
  21.  
  22.  
  23. return $content
  24.  

做系统的话,可以用下面的代码,也是copy来的。

PHP代码:

  1. function inject_check($sql_str) { 
  2.  
  3.  return eregi('select|insert|update|delete|\'|\/\*|\*|\.\.\/|\.\/|union|into|load_file|outfile'$sql_str);  // 进行过滤 
  4.  
  5.  
  6. function verify_id($id=null) { 
  7.  
  8.  if (!$id) { exit('没有提交参数!'); }  // 是否为空判断 
  9.  
  10.  elseif (inject_check($id)) { exit('提交的参数非法!'); }  // 注射判断 
  11.  
  12.  elseif (!is_numeric($id)) { exit('提交的参数非法!'); }  // 数字判断 
  13.  
  14.  $id = intval($id);  // 整型化 
  15.  
  16.  return $id
  17.  
  18.  
  19. function str_check( $str ) { 
  20.  
  21.  if (!get_magic_quotes_gpc()) {  // 判断magic_quotes_gpc是否打开 
  22.  
  23.   $str = addslashes($str);  // 进行过滤 
  24.  
  25.  } 
  26.  
  27.  $str = str_replace("_""\_"$str);  // 把 '_'过滤掉 
  28.  
  29.  $str = str_replace("%""\%"$str);  // 把 '%'过滤掉 
  30.  
  31.  return $str
  32.  
  33.  
  34. function post_check($post) { 
  35.  
  36.  if (!get_magic_quotes_gpc()) {  // 判断magic_quotes_gpc是否为打开 
  37.  
  38.   $post = addslashes($post);  // 进行magic_quotes_gpc没有打开的情况对提交数据的过滤 
  39.  
  40.  } 
  41.  
  42.  $post = str_replace("_""\_"$post);  // 把 '_'过滤掉 
  43.  
  44.  $post = str_replace("%""\%"$post);  // 把 '%'过滤掉 
  45.  
  46.  $post = nl2br($post);  // 回车转换 
  47.  
  48.  $post = htmlspecialchars($post);  // html标记转换 
  49.  
  50.  return $post
  51.  

Tags: sql防注入

分享到: