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

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

发布:smiling 来源: PHP粉丝网  添加日期:2021-07-29 11:51:29 浏览: 评论:0 

这篇文章主要介绍了php简单实现sql防注入的方法,涉及addslashes函数的使用及正则过滤的相关技巧,非常简单实用,需要的朋友可以参考下。

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

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

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

以下是一段copy来的代码:

PHP代码:

  1. $_POST = sql_injection($_POST); 
  2. $_GET = sql_injection($_GET); 
  3. function sql_injection($content
  4. if (!get_magic_quotes_gpc()) { 
  5. if (is_array($content)) { 
  6. foreach ($content as $key=>$value) { 
  7. $content[$key] = addslashes($value); 
  8. else { 
  9. addslashes($content); 
  10. return $content

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

PHP代码:

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

Tags: php防注入 sql防注入

分享到: