gpt4 book ai didi

php - MySQL 准备语句

转载 作者:行者123 更新时间:2023-11-29 01:14:41 25 4
gpt4 key购买 nike

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

最佳答案

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

这与正确使用 html_entities() 相结合以显示来自您的数据库的数据是保护您的页面免遭注入(inject)的可靠且良好的方法。我总是使用 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

关于php - MySQL 准备语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6379433/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com