这篇文章主要介绍了PHP函数addslashes和mysql_real_escape_string的区别,以及一个SQL注入漏洞介绍,需要的朋友可以参考下
 
 

首先:不要使用mysql_escape_string,它已被弃用,请使用mysql_real_escape_string代替它。

mysql_real_escape_string和addslashes的区别在于:

区别一:

addslashes不知道任何有关MySQL连接的字符集。如果你给所使用的MySQL连接传递一个包含字节编码之外的其他编码的字符串,它会很愉快地把所有值为字符‘、“、\和\x00的字节进行转义。如果你正在使用不同于8位和UTF-8的其它字符,这些字节的值不一定全部都是表示字符‘、“、\和\x00。可能造成的结果是,MySQL接收这些字符后出现错误。

如果要修正这个bug,可尝试使用iconv函数,将变量转为UTF-16,然后再使用addslashes进行转义。

这是不使用addslashes进行转义的原因之一。

区别二:

与addslashes对比,mysql_real_escape_string同时还对\r、\n和\x1a进行转义。看来,这些字符必须正确地告诉MySQL,否则会得到错误的查询结果。

这是不使用addslashes进行转义的另一个原因。

addslashes V.S. mysql_real_escape_string

在GBK里,0xbf27不是一个合法的多字符字符,但0xbf5c却是。在单字节环境里,0xbf27被视为0xbf后面跟着0×27(‘),同时0xbf5c被视为0xbf后面跟着0x5c(\)。

一个用反斜杠转义的单引号,是无法有效阻止针对MySQL的SQL注入攻击的。如果你使用addslashes,那么,我(攻击者,下同)是很幸运的。我只要注入一些类似0xbf27,然后addslashes将它修改为0xbf5c27,一个合法的多字节字符后面接着一个单引号。换句话说,我可以无视你的转义,成功地注入一个单引号。这是因为0xbf5c被当作单字节字符,而非双字节。

在这个演示中,我将使用MySQL 5.0和PHP的mysqli扩展。如果你想尝试,请确保你使用GBK。

创建一个名为users的表:

代码如下:
CREATE TABLE users(
username VARCHAR(32) CHARACTER SET GBK,
password VARCHAR(32) CHARACTER SET GBK,
PRIMARY KEY(username)
);

下面的代码模拟只使用addslashes(或magic_quotes_gpc)对查询数据进行转义时的情况:

代码如下:
<?php
$mysql = array();
$db = mysqli_init();
$db->real_connect('localhost', 'lorui', 'lorui.com', 'lorui_db');
/* SQL注入示例 */
$_POST['username'] = chr(0xbf) . chr(0×27) . ‘ OR username = username /*'; $_POST['password'] = ‘guess'; $mysql['username'] = addslashes($_POST['username']); $mysql['password'] = addslashes($_POST['password']); $sql = “SELECT * FROM users WHERE username = ‘{$mysql['username']}' AND password = ‘{$mysql['password']}'”; $result = $db->query($sql); if ($result->num_rows) { /* 成功 */ } else { /* 失败 */ }

尽管使用了addslashes,我还是可以在不知道用户名和密码的情况下成功登录。我可以轻松的利用这个漏洞进行SQL注入。

要以免这种漏洞,使用mysql_real_escape_string、准备语句(Prepared Statements,即“参数化查询”)或者任意一款主流的数据库抽象类库。

最新文章

  1. [LeetCode] Maximum Gap 求最大间距
  2. iOS开发人员不容错过的10大工具
  3. springmvc的单文件上传
  4. linux怎么模糊查找一个文件
  5. IOS之未解问题--关于IOS图像渲染CPU和GPU
  6. [vm]exsi的名词
  7. laravel transaction : laravel 的事务是不支持eloquent的, 要用DB::的方式
  8. webService调用的N种方式
  9. win7 dos命令窗口内容显示不全解决办法--将命令执行结果输出到一个文件中
  10. delphi 博客地址收藏
  11. Flash Builder 4.6 界面显示一半中文一半英文?
  12. Spring3 M2 quartz-2.1.7 解决bean不能注入问题
  13. OpenCV, color reduction method
  14. C++ 拷贝构造函数、拷贝赋值运算符、析构函数
  15. Window10升级遇到大坑错误代码:0xc000000e完美解决方案
  16. 干了这杯Java之集合概览
  17. jquery添加
  18. 024_nginx之backlog坑
  19. Ubuntu18.10下安装Qt5.12过程记录
  20. 131.005 Unsupervised Learning - Cluster | 非监督学习 - 聚类

热门文章

  1. 常用Linux shell命令汇总
  2. CentOS 6.2下log4cplus的使用
  3. [TI-Sitara]启动流程
  4. shell中日期操作
  5. C++中数字和字符串的转换
  6. [mysql] Navicat for mysql_导入导出表结构
  7. Instant Run requires &#39;Tools | Android | Enable ADB integration&#39; to be enabled.
  8. 【BZOJ】1088: [SCOI2005]扫雷Mine(递推)
  9. 【BZOJ】1058: [ZJOI2007]报表统计(splay+set)
  10. 修复mysql:[ERROR] Native table ‘performance_schema’