Mysql数据库安全性问题【防注入】

一、SQL注入实例

后台的插入语句代码:

$unsafe_variable = $_POST['user_input'];   
mysql_query("INSERT INTO `table` (`column`) VALUES ('$unsafe_variable')");  
 
 
  • 1
  • 2

当POST的内容为:

value'); DROP TABLE table;--
 
 
  • 1

以上的整个SQL查询语句变成:

INSERT INTO `table` (`column`) VALUES('value'); DROP TABLE table;--')  
 
 
  • 1

二、防止SQL注入措施

1.使用预处理语句和参数化查询。(‘Use prepared statements and parameterized queries.’) 
SQL语句和查询的参数分别发送给数据库服务器进行解析。这种方式有2种实现: 
(1)使用PDO(PHP data object)

$stmt = $pdo->prepare('SELECT * FROM employees WHERE name = :name');  
$stmt->execute(array('name' => $name));  
foreach ($stmt as $row) {  
    // do something with $row  
}  
 
 
  • 1
  • 2
  • 3
  • 4
  • 5

(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  
}  
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

2.对查询语句进行转义(最常见的方式)

$unsafe_variable = $_POST["user-input"];  
$safe_variable = mysql_real_escape_string($unsafe_variable);  
mysql_query("INSERT INTO table (column) VALUES ('" . $safe_variable . "')");  
 
 
  • 1
  • 2
  • 3
$mysqli = new mysqli("server", "username", "password", "database_name");  
// TODO - Check that connection was successful.  
$unsafe_variable = $_POST["user-input"];  
$stmt = $mysqli->prepare("INSERT INTO table (column) VALUES (?)");  
// TODO check that $stmt creation succeeded  
// "s" means the database expects a string  
$stmt->bind_param("s", $unsafe_variable);  
$stmt->execute();  
$stmt->close();  
$mysqli->close();  
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

3.限制引入的参数

$orders  = array("name","price","qty"); //field names  
$key     = array_search($_GET['sort'],$orders)); // see if we have such a name  
$orderby = $orders[$key]; //if not, first one will be set automatically. smart enuf :)  
$query   = "SELECT * FROM `table` ORDER BY $orderby"; //value is safe  
 
 
  • 1
  • 2
  • 3
  • 4

4.对引入参数进行编码

SELECT password FROM users WHERE name = 'root'            --普通方式  
SELECT password FROM users WHERE name = 0x726f6f74        --防止注入  
SELECT password FROM users WHERE name = UNHEX('726f6f74') --防止注入  

set @INPUT =  hex("%实验%");  
select * from login where reset_passwd_question like unhex(@INPUT) ;  
 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

有一些讨论意见,所以我最后想弄清楚。这两种方法非常相似,但它们在某些方面有点不同: 
x前缀只能用于数据列如char、varchar、文本块,二进制,等等。 
其使用也有点复杂,如果你要插入一个空字符串。你必须完全替代”,或者你会得到一个错误。 
任何列工作;您不必担心空字符串。

这里写图片描述

参考stackoverflow:http://stackoverflow.com/questions/60174/how-can-i-prevent-sql-injection-in-php

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值