让代码更简单

php防止sql注入原理介绍

重要:本文最后更新于2018-11-13 20:27:49,某些文章具有时效性,若有错误或已失效,请在下方留言或联系代码狗

前不久代码狗博客居然被黑客入侵了,还好这名黑客算是有职业操守,没有干太大的坏事,只是将我最新更新的文章给改成了用英文写的骂IS的话,在后台恢复之后,立马查了很多关于入侵的例子,最常见的就是sql注入了,不过WordPress代码还是相当的安全,不应该存在这样的漏洞才对,于是就将自己写的一些功能代码查了个遍,仍然没有找到原因,偶然下发现WordPress要求更新,立刻意识到好像阿里云提示了我很多次网站存在漏洞,我直接给忽略了,看来是自作孽啊! 立刻更新了WordPress到最新版,到阿里云后台检查漏洞,果然没有了,但服务器程序却仍然存在2处问题,正在修复中,完成后与大家分享经验!下面是一篇比较基础的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,这个替换解决了注入的问题,同时也解决了中文乱码的一些问题。

感觉很棒!可以赞赏支持我哟~

0 打赏

评论 (0)

登录后评论
QQ咨询 邮件咨询 狗哥推荐