php防止sql注入原理介绍

虽然国内很多php程序员仍在依靠addslashes防止sql注入,还是建议大家加强中文防止sql注入的检查。addslashes的问题在 于黑客 可以用0xbf27来代替单引号,而addslashes只是将0xbf27修改为0xbf5c27,成为一个有效的多字节字符,其中的0xbf5c仍会 被看作是单引号,所以addslashes无法成功拦截。

当然addslashes也不是毫无用处,它是用于单字节字符串的处理,多字节字符还是用mysql_real_escape_string吧。

打开magic_quotes_gpc来防止sql注入

php.ini中有一个设置:magic_quotes_gpc = off
  这个默认是关闭的,如果它打开后将自动把用户提交对sql的查询进行转换,
  比如把 ‘ 转为 ‘等,对于防止sql注射有重大作用。

如果magic_quotes_gpc=off,则使用addslashes()函数

另外对于php手册中get_magic_quotes_gpc的举例:

代码如下

if (!get_magic_quotes_gpc()) {

  $lastname = addslashes($_post[‘lastname’]);

  } else {

  $lastname = $_post[‘lastname’];

}

最好对magic_quotes_gpc已经开放的情况下,还是对$_post[’lastname’]进行检查一下。

再说下mysql_real_escape_string和mysql_escape_string这2个函数的区别:

mysql_real_escape_string 必须在(php 4 >= 4.3.0, php 5)的情况下才能使用。否则只能用 mysql_escape_string ,两者的区别是:mysql_real_escape_string 考虑到连接的当前字符集,而mysql_escape_string 不考虑。

(1)mysql_real_escape_string — 转义 sql 语句中使用的字符串中的特殊字符,并考虑到连接的当前字符集

使用方法如下:

代码如下

$sql = “select count(*) as ctr from users where username02.='”.mysql_real_escape_string($username).”‘ and 03.password='”. mysql_real_escape_string($pw).”‘ limit 1″;

自定函数

代码如下

function inject_check($sql_str) {
return eregi(‘select|insert|and|or|update|delete|’|/*|*|../|./|union|into|load_file|outfile’, $sql_str);
}

function verify_id($id=null) {
if(!$id) {
exit(‘没有提交参数!’);
} elseif(inject_check($id)) {
exit(‘提交的参数非法!’);
} elseif(!is_numeric($id)) {
exit(‘提交的参数非法!’);
}
$id = intval($id);

return $id;
}

function str_check( $str ) {
if(!get_magic_quotes_gpc()) {
$str = addslashes($str); // 进行过滤
}
$str = str_replace(“_”, “_”, $str);
$str = str_replace(“%”, “%”, $str);

return $str;
}

function post_check($post) {
if(!get_magic_quotes_gpc()) {
$post = addslashes($post);
}
$post = str_replace(“_”, “_”, $post);
$post = str_replace(“%”, “%”, $post);
$post = nl2br($post);
$post = htmlspecialchars($post);

return $post;
}

总结一下:

* addslashes() 是强行加;

* mysql_real_escape_string() 会判断字符集,但是对php版本有要求;
* mysql_escape_string不考虑连接的当前字符集。
dz中的防止sql注入就是用addslashes这个函数,同时在dthmlspecialchars这个函数中有进行一些替换$string = preg_replace(/&((#(d{3,5}|x[a-fa-f0-9]{4}));)/, &1,这个替换解决了注入的问题,同时也解决了中文乱码的一些问题。

http://www.bkjia.com/phpjc/629626.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/629626.htmltecharticle虽然国内很多php程序员仍在依靠addslashes防止sql注入,还是建议大家加强中文防止sql注入的检查。addslashes的问题在 于黑客 可以用0xbf27来代替…

Posted in 未分类

发表评论