成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

PHP中該怎樣防止SQL注入?

Panda / 1792人閱讀

摘要:預(yù)處理語句和參數(shù)分別發(fā)送到數(shù)據(jù)庫服務(wù)器進(jìn)行解析,參數(shù)將會(huì)被當(dāng)作普通字符處理。解析當(dāng)你將語句發(fā)送給數(shù)據(jù)庫服務(wù)器進(jìn)行預(yù)處理和解析時(shí)發(fā)生了什么通過指定占位符一個(gè)或者一個(gè)上面例子中命名的,告訴數(shù)據(jù)庫引擎你想在哪里進(jìn)行過濾。

問題描述:

如果用戶輸入的數(shù)據(jù)在未經(jīng)處理的情況下插入到一條SQL查詢語句,那么應(yīng)用將很可能遭受到SQL注入攻擊,正如下面的例子:

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

因?yàn)橛脩舻妮斎肟赡苁沁@樣的:

value"); DROP TABLE table;--

那么SQL查詢將變成如下:

INSERT INTO table (column) VALUES("value"); DROP TABLE table;--")

應(yīng)該采取哪些有效的方法來防止SQL注入?

最佳回答(來自Theo):

使用預(yù)處理語句和參數(shù)化查詢。預(yù)處理語句和參數(shù)分別發(fā)送到數(shù)據(jù)庫服務(wù)器進(jìn)行解析,參數(shù)將會(huì)被當(dāng)作普通字符處理。這種方式使得攻擊者無法注入惡意的SQL。 你有兩種選擇來實(shí)現(xiàn)該方法:

1、使用PDO:

$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

注意,在默認(rèn)情況使用PDO并沒有讓MySQL數(shù)據(jù)庫執(zhí)行真正的預(yù)處理語句(原因見下文)。為了解決這個(gè)問題,你應(yīng)該禁止PDO模擬預(yù)處理語句。一個(gè)正確使用PDO創(chuàng)建數(shù)據(jù)庫連接的例子如下:

$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);

在上面的例子中,報(bào)錯(cuò)模式(ATTR_ERRMODE)并不是必須的,但建議加上它。這樣,當(dāng)發(fā)生致命錯(cuò)誤(Fatal Error)時(shí),腳本就不會(huì)停止運(yùn)行,而是給了程序員一個(gè)捕獲PDOExceptions的機(jī)會(huì),以便對錯(cuò)誤進(jìn)行妥善處理。 然而,第一個(gè)setAttribute()調(diào)用是必須的,它禁止PDO模擬預(yù)處理語句,而使用真正的預(yù)處理語句,即有MySQL執(zhí)行預(yù)處理語句。這能確保語句和參數(shù)在發(fā)送給MySQL之前沒有被PHP處理過,這將使得攻擊者無法注入惡意SQL。了解原因,可參考這篇博文:PDO防注入原理分析以及使用PDO的注意事項(xiàng)。 注意在老版本的PHP(<5.3.6),你無法通過在PDO的構(gòu)造器的DSN上設(shè)置字符集,參考:silently ignored the charset parameter。

解析

當(dāng)你將SQL語句發(fā)送給數(shù)據(jù)庫服務(wù)器進(jìn)行預(yù)處理和解析時(shí)發(fā)生了什么?通過指定占位符(一個(gè)?或者一個(gè)上面例子中命名的 :name),告訴數(shù)據(jù)庫引擎你想在哪里進(jìn)行過濾。當(dāng)你調(diào)用execute的時(shí)候,預(yù)處理語句將會(huì)與你指定的參數(shù)值結(jié)合。 關(guān)鍵點(diǎn)就在這里:參數(shù)的值是和經(jīng)過解析的SQL語句結(jié)合到一起,而不是SQL字符串。SQL注入是通過觸發(fā)腳本在構(gòu)造SQL語句時(shí)包含惡意的字符串。所以,通過將SQL語句和參數(shù)分開,你防止了SQL注入的風(fēng)險(xiǎn)。任何你發(fā)送的參數(shù)的值都將被當(dāng)作普通字符串,而不會(huì)被數(shù)據(jù)庫服務(wù)器解析。回到上面的例子,如果$name變量的值為 ’Sarah’; DELETE FROM employees ,那么實(shí)際的查詢將是在 employees 中查找 name 字段值為 ’Sarah’; DELETE FROM employees 的記錄。 另一個(gè)使用預(yù)處理語句的好處是:如果你在同一次數(shù)據(jù)庫連接會(huì)話中執(zhí)行同樣的語句許多次,它將只被解析一次,這可以提升一點(diǎn)執(zhí)行速度。 如果你想問插入該如何做,請看下面這個(gè)例子(使用PDO):
$preparedStatement = $db->prepare("INSERT INTO table (column) VALUES
(:column)");
$preparedStatement->execute(array("column" => $unsafeValue));

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/22763.html

相關(guān)文章

  • php操作mysql防止sql注入(合集)

    摘要:參考中如何防止注入?yún)?shù)化查詢?yōu)槭裁茨軌蚍乐棺⑷肷厦嫣峁┑馁Y料比較多,下面根據(jù)自己的理解整理出來。使用的預(yù)處理參數(shù)化查詢可以有效防止注入。我們在上面預(yù)處理參數(shù)化查詢是在中進(jìn)行防注入操作的,其實(shí)也內(nèi)置了一個(gè)預(yù)處理的模擬器,叫做。 由于segmentfault在處理特殊字符時(shí)也并非完美,所以下面文章中有些符號(hào)被轉(zhuǎn)換了,請到本人博客下載原文txt http://www.yunxi365.cn/...

    kviccn 評(píng)論0 收藏0
  • 防止sql注入的方法

    摘要:打開來防止注入注入是非常危險(xiǎn)的問題,小則網(wǎng)站后臺(tái)被入侵,重則整個(gè)服務(wù)器淪陷,所以一定要小心。雖然國內(nèi)很多程序員仍在依靠防止注入,還是建議大家加強(qiáng)中文防止注入的檢查。 1. 打開magic_quotes_gpc來防止SQL注入 SQL注入是非常危險(xiǎn)的問題,小則網(wǎng)站后臺(tái)被入侵,重則整個(gè)服務(wù)器淪陷, 所以一定要小心。php.ini中有一個(gè)設(shè)置: magic_quotes_gpc = Off...

    GHOST_349178 評(píng)論0 收藏0
  • php安全問題思考

    摘要:用戶提交過來的數(shù)據(jù)都是不可信的,所以,在查庫或入庫前需要對提交過來的數(shù)據(jù)進(jìn)行過濾或字符的轉(zhuǎn)換處理,以防止注入或攻擊等問題。 用戶提交過來的數(shù)據(jù)都是不可信的,所以,在查庫或入庫前需要對提交過來的數(shù)據(jù)進(jìn)行過濾或字符的轉(zhuǎn)換處理,以防止SQL注入或xss攻擊等問題。 一、防止SQL注入 什么是SQL注入攻擊? 所謂SQL注入,就是通過把SQL命令插入到Web表單提交或輸入域名或頁面請求的查詢字...

    alphahans 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<