當前位置:首頁 > 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防注入

分享到:

广西快3最大遗漏值统计表