首頁  >  文章  >  後端開發  >  php三個函數、兩種選擇防止sql注入

php三個函數、兩種選擇防止sql注入

angryTom
angryTom轉載
2019-10-16 10:23:392744瀏覽

php三個函數、兩種選擇防止sql注入

三個函數:

1. addslashes($string):用反斜線引用字串中的特殊字符' " \

$username=addslashes($username);

2. mysql_escape_string($string):用反斜線轉義字串中的特殊字符,用於mysql_query()查詢。

$username=mysql_escape_string($username);

3. mysql_real_escape_string($string):轉義SQL語句中使用的字串中的特殊字符,並考慮到連接的當前字符集,需要保證當前是連接狀態才能用該函數,否則會報警告。不轉義%與_

$username=mysql_real_escape_string($username);

兩種選擇:

#1. 使用PDO

$stmt = $pdo->prepare('SELECT * FROM user WHERE name = :name');
$stmt->execute(array(':name' => $name));
foreach ($stmt as $row) {
// do something with $row
}

2. 使用mysqli

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

 更多PHP相關知識,請造訪PHP中文網!

以上是php三個函數、兩種選擇防止sql注入的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:www.phplaozhang.com。如有侵權,請聯絡admin@php.cn刪除