探讨php中防止SQL注入最好的方法是什么


Posted in PHP onJune 10, 2013

如果用户输入的是直接插入到一个SQL语句中的查询,应用程序会很容易受到SQL注入,例如下面的例子:

$unsafe_variable = $_POST['user_input'];
mysql_query("INSERT INTO table (column) VALUES ('" . $unsafe_variable . "')");

这是因为用户可以输入类似VALUE“); DROP TABLE表; - ,使查询变成:
INSERT INTO table (column) VALUES('VALUE'); DROP TABLE table;'

我们应该怎么防止这种情况呢?请看下面
使用预备义语句和参数化查询。对于带有任何参数的sql语句都会被发送到数据库服务器,并被解析!对于攻击者想要恶意注入sql是不可能的!
实现这一目标基本上有两种选择:
1.使用PDO(PHP Data Objects ):
$stmt = $pdo->prepare('SELECT * FROM employees WHERE name = :name');
$stmt->execute(array(':name' => $name));
foreach ($stmt as $row) {
    // do something with $row
}

2.使用mysqli:
$stmt = $dbConnection->prepare('SELECT * FROM employees WHERE name = ?');
$stmt->bind_param('s', $name);
$stmt->execute();
$result = $stmt->get_result();
while ($row = $result->fetch_assoc()) {
    // do something with $row
}

PDO(PHP数据对象)
注意当使用PDO访问MySQL数据库真正的预备义语句并不是默认使用的!为了解决这个问题,你必须禁用仿真准备好的语句。
使用PDO创建连接的例子如下:
$dbConnection = new PDO('mysql:dbname=dbtest;host=127.0.0.1;charset=utf8', 'user', 'pass');
$dbConnection->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
$dbConnection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

在上面例子中错误模式ERRMODE不是严格必须的,但是建议添加它。当运行出错产生致命错误时,这种方法脚本不会停止。并给开发人员捕捉任何错误的机会(当抛出PDOException异常时)。
setAttribute()那一行是强制性的,它告诉PDO禁用仿真预备义语句,使用真正的预备义语句。这可以确保语句和值在发送给MySQL数据库服务器前不被PHP解析(攻击者没有机会注入恶意的SQL).
当然你可以在构造函数选项中设置字符集参数,特别注意'老'的PHP版本(5.3.6)会在DSN中忽略掉字符集参数。

Explanation(解释)
在你传递的sql预备义语句 被数据库服务器解析和编译会发生什么?通过指定的字符(在上面例子中像a?或者像:name)告诉数据库引擎你想要过滤什么.然后调用execute执行结合好的预备义语句和你指定的参数值.

这里最重要的是,该参数值是和预编译的语句结合的,而不是和一个SQL字符串.SQL注入的工作原理是通过欺骗手段创建的SQL脚本包括恶意字符串发送到数据库.因此,通过发送实际的分开的sql参数,你会降低风险.使用准备好的语句时,你发送的任何参数,将只被视为字符串(虽然数据库引擎可能会做一些参数的优化,当然最终可能会为数字).在上面的例子中,如果变量$name包含'sarah';DELETE * FROM employees,结果只会是一个搜索的字符串"'sarah';DELETE * FROM employees",你不会得到一个空表。

使用准备好的语句的另一个好处是,如果你在同一会话中多次执行相同的语句,这将只被解析和编译一次,给你一些的速度增长。
哦,既然你问如何进行插入,这里是一个例子(使用PDO):

$preparedStatement = $db->prepare('INSERT INTO table (column) VALUES (:column)');
$preparedStatement->execute(array(':column' => $unsafeValue));
PHP 相关文章推荐
PHP中的cookie
Nov 26 PHP
php gd2 上传图片/文字水印/图片水印/等比例缩略图/实现代码
May 15 PHP
PHP中unset,array_splice删除数组中元素的区别
Jul 28 PHP
在Win7 中为php扩展配置Xcache
Oct 08 PHP
PHP has encountered a Stack overflow问题解决方法
Nov 03 PHP
详解PHP中的PDO类
Jul 06 PHP
CodeIgniter控制器之业务逻辑实例分析
Jan 20 PHP
php数据访问之增删改查操作
May 09 PHP
PHP获取当前URL路径的处理方法(适用于多条件筛选列表)
Feb 10 PHP
PHP数组式访问接口ArrayAccess用法分析
Dec 28 PHP
PHP实现redis限制单ip、单用户的访问次数功能示例
Jun 16 PHP
php使用gearman进行任务分发操作实例详解
Feb 26 PHP
php防注入,表单提交值转义的实现详解
Jun 10 #PHP
PHP获取当前页面完整URL的实现代码
Jun 10 #PHP
如何判断php数组的维度
Jun 10 #PHP
joomla jce editor 解决上传中文名文件失败问题
Jun 09 #PHP
php缩放图片(根据宽高的等比例缩放)实例介绍
Jun 09 #PHP
探讨php define()函数及defined()函数使用详解
Jun 09 #PHP
如何用php获取程序执行的时间
Jun 09 #PHP
You might like
php实现session自定义会话处理器的方法
2015/01/27 PHP
使用PHP接受文件并获得其后缀名的方法
2015/08/05 PHP
一文看懂PHP进程管理器php-fpm
2020/06/01 PHP
IE和firefox浏览器的event事件兼容性汇总
2009/12/06 Javascript
JS操作iframe里的dom(实例讲解)
2014/01/29 Javascript
jquery网页回到顶部效果(图标渐隐,自写)
2014/06/16 Javascript
JavaScript的作用域和块级作用域概念理解
2014/09/21 Javascript
小议JavaScript中Generator和Iterator的使用
2015/07/29 Javascript
基于JQuery实现仿网易邮箱全屏动感滚动插件fullPage
2015/09/20 Javascript
小巧强大的jquery layer弹窗弹层插件
2015/12/06 Javascript
JS实现table表格数据排序功能(可支持动态数据+分页效果)
2016/05/26 Javascript
jQuery的Each比JS原生for循环性能慢很多的原因
2016/07/05 Javascript
JS 实现导航菜单中的二级下拉菜单的几种方式
2016/10/31 Javascript
jQuery实现文档树效果
2017/02/20 Javascript
微信小程序实现顶部下拉菜单栏
2018/11/04 Javascript
详解JavaScript栈内存与堆内存
2019/04/04 Javascript
详解package.json版本号规则
2019/08/01 Javascript
浅谈layui 绑定form submit提交表单的注意事项
2019/10/25 Javascript
vue实现评价星星功能
2020/06/30 Javascript
python实现dict版图遍历示例
2014/02/19 Python
python有证书的加密解密实现方法
2014/11/19 Python
Python自动化测试Eclipse+Pydev 搭建开发环境
2016/08/15 Python
Python制作exe文件简单流程
2019/01/24 Python
Python类的继承用法示例
2019/01/31 Python
python 读写文件包含多种编码格式的解决方式
2019/12/20 Python
双向RNN:bidirectional_dynamic_rnn()函数的使用详解
2020/01/20 Python
python实现控制台输出彩色字体
2020/04/05 Python
CSS3截取字符串实例代码【推荐】
2018/06/07 HTML / CSS
基于HTML5超酷摄像头(HTML5 webcam)拍照功能实现代码
2012/12/13 HTML / CSS
Mio Skincare英国官网:身体紧致及孕期身体护理
2018/08/19 全球购物
经理管理专业毕业自荐书范文
2014/02/12 职场文书
大学学生会竞选演讲稿
2014/04/25 职场文书
领导干部群众路线剖析材料
2014/10/09 职场文书
小学优秀教师先进事迹材料
2014/12/16 职场文书
2015年个人思想总结
2015/03/09 职场文书
毕业答辩开场白范文
2015/05/27 职场文书