MySQL准备语句

时间:2011-06-16 22:40:14

标签: php mysql sql-injection

我只是想知道是否有一种方法可以在MySQL中使用某种形式的预处理语句,因此我不必转义所有输入,我也不必将所有文件从MySQL切换到MySQLi。我真的不相信转义函数,所以如果有任何替代方法可以在常规MySQL中运行,那就太棒了。

2 个答案:

答案 0 :(得分:7)

使用PDO (PHP Data Objects)连接到MySQL数据库。此方法将确保所有数据库输入始终被视为文本字符串,您将永远不必进行任何手动转义。

这与正确使用html_entities()以显示数据来自数据库相结合是保护页面免于注入的一种可靠且好的方法。我总是使用PDO来处理项目中的所有数据库连接。

创建数据库对象(在这种情况下强制执行某种字符编码):

try {
    $db = new PDO("mysql:host=[hostname];dbname=[database]",'[username]','[password]');
    $db->setAttribute(PDO::MYSQL_ATTR_INIT_COMMAND, "SET NAMES utf8");
    $db->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
    $db->exec('SET NAMES utf8');
} catch (PDOException $e) {
    echo $e->getMessage();
}

然后像这样使用它:

$id = 1;
$q = $db->prepare('SELECT * FROM Table WHERE id = ?');
$q->execute(array($id));
$row = $q->fetch();
echo $row['Column_1'];

$q = $db->prepare('UPDATE Table SET Column_1 = ?, Column_2 = ? WHERE id = ?');
$q->execute(array('Value for Column_1','Value for Column_2',$id));

并使用通配符:

$search = 'John';
$q = $db->prepare('SELECT * FROM Table WHERE Column_1 LIKE ?');
$q->execute(array('%'.$search.'%'));
$num = $q->rowCount();
if ($num > 0) {
  while ($row = $q->fetch()) {
    echo $row['Column_1'];
  }
} else {
  echo "No hits!";
}

了解更多:

How can I prevent SQL injection in PHP?

When *not* to use prepared statements?

how safe are PDO prepared statements

http://php.net/manual/en/book.pdo.php

答案 1 :(得分:0)

如果您不想处理转义输入,您可以随时对其进行模式匹配,然后发送您的预先编写的语句。如果您执行的语句相对较少,那么这真的值得付出努力。