首頁 後端開發 php教程 在PHP中全面禁止SQL注進式攻擊之一

在PHP中全面禁止SQL注進式攻擊之一

Dec 24, 2016 am 09:55 AM
php sql

 在本系列文章中,我們將全面探討如何在PHP開發環境中全面禁止SQL注進式攻擊,並給出一個具體的開發範例。

  一、 引言

  PHP是一種力量強盛但相當輕易學習的伺服器端腳本語言,即使是經驗未幾的程式設計師也能夠應用它來創立複雜的動態的web站點。然而,它在實現因特網服務的機密和安全方面卻經常存在著許多艱苦。在本系列文章中,我們將向讀者先容進行web開發所必需的安全背景以及PHP特定的知識和代碼-你可以藉以保護你自己的web利用程序的安全性和一致性。首先,我們簡略地回想一下伺服器安全標題-展現你如何訪問一個共享宿主環境下的私人信息,使開發者脫離開生產伺服器,保持最新的軟體,供給加密的頻道,並且把持對你的系統的存取。

  然後,我們討論PHP腳本實現中的廣泛存在的脆弱性。我們將說明如何保護你的腳本免於SQL注進,防止跨站點腳本化和遠端履行,並且禁止對臨時文件及會話的'劫持'。

  在最後一篇中,我們將實現一個安全的Web利用程式。你將學習如何驗證使用者身份,授權並追蹤利用程式應用,避免資料喪失,安全地履行高風險性的系統命令,並能夠安全地應用web服務。無論你是否有足夠的PHP安全開發經驗,本系列文章都會供給豐富的資訊來幫助你建立更安全的線上利用程式。

  二、 什麼是SQL注進

  假如你打算永遠不應用某些資料的話,那麼把它們儲存於一個資料庫是毫無意義的;由於資料庫的設計目標是為了方便地存取和把持資料庫中的數據。但是,假如只是簡略地這樣做則有可能會導致埋伏的災害。這種情況並不重要是由於你自己可能偶然刪除資料庫中的一切;而是由於,當你試圖完成某項'無辜'的任務時,你有可能被某些人所'劫持'-應用他自己的損壞性資料來取代你自己的資料。我們稱這種代替為'注進'。

  實在,每當你請求用戶輸進結構一個資料庫查詢,你是在答應當用戶參與建立一個訪問資料庫伺服器的命令。一位友愛的用戶可能對實現這樣的把持感到很滿足;然而,一位惡意的用戶將會試圖發明一種方法來扭曲該命令,從而導致該被的扭曲命令刪除數據,甚至做出更為危險的事情。身為一個程式設計師,你的任務是尋找一種方法來避免這樣的惡意攻擊。

  三、 SQL注進工作原理

  結構一個資料庫查詢是一個非常直接的過程。典範地,它會遵守以下思路來實現。僅為闡明標題,我們將假定你有一個葡萄酒數據庫表格'wines',其中有一個字段為'variety'(即葡萄酒類型):

  1. 供給一個表單-答利用戶提交某些要搜索的內容。讓我們假定使用者選擇搜尋類型為'lagrein'的葡萄酒。


 2. 檢索該用戶的搜尋術語,並且保留它-通過把它賦給一個如下所示的變量來實現: 

  $variety = $_POST['variety'];  $variety = $_POST['variety']; $variety的值現在為:

  lagrein

  3. 然後,應用該變數在WHERE子句中結構一個資料庫查詢:

  $query = 'SELECT * FROMo wines w.所以,變數$query的值現在如下所示:

  SELECT * FROM wines WHERE variety='lagrein'

  4. 把該查詢提交給MySQL伺服器。

  5. MySQL傳回wines表格中的所有記錄-其中,欄位variety的值為'lagrein'。



  到目前為止,這應該是一個你所熟悉的而且是非常輕鬆的過程。遺憾的是,有時我們所熟悉並感到舒適的過程卻輕易導致我們產生驕傲情感。現在,讓我們再重新分析一下剛才建置的查詢。

  1. 你創立的這個查詢的固定部分以一個單引號結束,你將應用它來描寫變數值的開端:

  $query = ' SELECT * FROM wines WHERE variety = '';原有的固定不變的部分與包含使用者提交的變數的值:

  $query .= $variety; 

  3. 然後,你應用另一個單引號來連接此成果-描寫該變數值的結束:

  $ query .= ''';

  於是,$query的值如下所示:

  SELECT * FROM wines WHERE variety = 'lagrein'🎀在本文範例中,你正在應用單字(也可能是一組單字)來指明一種葡萄酒類型。因此,該查詢的構建是無任何標題的,結果也會是你所期看的-一個葡萄酒類型為'lagrein'的葡萄酒列表。現在,讓我們想像,既然你的用戶不是輸進一個簡略的類型為'lagrein'的葡萄酒類型,而是輸進了下列內容(留心包含其中的兩個標點符號):

  lagrein' or 1= 1;

  現在,你持續應用前面固定的部分來結構你的查詢(在此,我們只顯示$query變數的成果值):

  SELECT * FROM wines WHERE variety = '  SELECT * FROM wines WHERE variety = '使用者輸進內容的變數的值與之進行連接(在此,以粗體顯示):

  SELECT * FROM wines WHERE variety = 'lagrein' 或 1=1;

  最後,加上高低面的下引號:

  SELECT * FROM wines WHERE variety = 'lagrein' or 1=1;'

  於是,這個查詢成果與你的期看會相當不同。事實上,現在你的查詢包含的不是一條而是兩條指令,由於用戶輸進的最後的分號已經結束了第一條指令(進行記錄選擇)從而開端了一條新的指令。在本例中,第二條指令,除了一個簡略的單引號之外別無意義;但是,第一條指令也不是你所想實現的。當使用者把一個單引號放到他的輸進內容的中間時,他結束了期看的變數的值,並且引進了另一個條件。因此,不再是檢索那些variety為'lagrein'的記錄,而是在檢索那些滿足兩個尺度中任何一個(第一個是你的,而第二個是他的-variety為'lagrein'或1即是1)的記錄。既然1總是1,因此,你會檢索到所有的記錄!


  你可能反對:我不會應用雙引號來代替單引號來描寫用戶提交的變數嗎?不錯,這至少可以減慢惡意用戶的攻擊。 (在先前的文章中,我們提示過你:應禁止所有對用戶的錯誤通知信息。假如在此天生一條錯誤消息,那麼,它有可能恰恰幫助了攻擊者-供給一個關於他的攻擊為什麼失敗的具體的說明。能夠輕易地向他供給有關於該表格的內部結構,從而也就向他供給了使其以後實現更為狠毒目標的一個重要參考。假如你的資料庫中不是包含顯然無害的酒之類資訊而是包含例如一個含有僱員年收進的列表,那麼,剛才描寫情況會是特別真實的。 

  而從理論角度分析,這種攻擊也的確是一件很可怕的事情。由於把意外的內容注進到你的查詢中,所以,此用戶能夠實現將你的資料庫訪問轉化為用於實現他自己的目標。因此現在,你的資料庫已經對他打開-正如對你敞開一樣。


  四、 PHP和MySQL注進

  如我們前面所描寫的,PHP,從本身設計來說,並沒有做什麼特別的事情-除了按照你的唆使把持之外。因此,假如為惡意使用者所用,它也只是按照請求'答應'特別設計的攻擊-例如我們前面所描寫的那樣。

  我們將假定,你不會故意地或甚至是偶然地結構一個具有損壞性後果的數據庫查詢-於是,我們假定標題出在來自你的用戶的輸進方面。現在,讓我們來更過細地分析一下用戶可能向你的腳本供給資訊的各種道路。

  五、 使用者輸進的類型

  如今,使用者能夠影響你的腳本的行動已變得越來越複雜。

  使用者輸進最明顯的起源當然是表單上的一個文字輸進域。應用這樣的一個網域,你簡直是故意教唆一個使用者輸進任意資料。而且,你向使用者供給了一個很大的輸進範疇;沒有什麼措施能夠使你提前限制一個使用者能夠輸進的資料類型(儘管你能夠選擇限制它的長度)。這正是盡大多數的注進式攻擊來源重要來自於無防禦的表單域的原因。

  但是,還存在其它的攻擊源,並且稍加思考你就會想到的一種潛於表單後台的技巧-POST方法!透過簡單地分析顯示在瀏覽器的導航工具列中的URI,一個擅長觀察的使用者能夠輕易地看出是什麼訊息傳遞到了一個腳本。儘管典範情況下這樣的URI是以編程方法天生的,但是,沒有什麼措施能夠禁止一個惡意的用戶簡略地把一個帶有一個不適當的變量值的URI輸進到一個瀏覽器中-而這樣埋伏地打開一個可能會被其濫用的資料庫。 

  限制使用者輸進內容的常用策略是在表單中供給一個選擇框,而不是一個輸進框。這種控制能夠強迫使用者從一組預先定義的值中進行選擇,並且能夠在必定程度上禁止使用者輸進期看不到的內容。但是正如一個攻擊者可能'哄騙'一個URI(也即是,創立一個能夠模仿一個可信任的卻無效的URI)一樣,他也可能模仿創立你的表單及其自己的版本,並因此在選項框中應用非法的而不是預先定義的安全選擇。要實現這一點是極其簡略的;他僅需要觀察源碼,然後剪切並且粘貼該表單的源代碼-然後一切為他敞開大門。


 在修正該選擇之後,他就能夠提交表單,並且他的無效的指令就會被接收,就像它們是原始的指令一樣。因此,該用戶可以應用許多不同的方法試圖把惡意的程式碼注進到一個腳本中。




 以上就是在PHP中全面禁止SQL注進式攻擊之一的內容,更多相關內容請關注PHP中文網(www.php.cn)!


本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 Dec 24, 2024 pm 04:42 PM

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 Dec 20, 2024 am 11:31 AM

Visual Studio Code,也稱為 VS Code,是一個免費的原始碼編輯器 - 或整合開發環境 (IDE) - 可用於所有主要作業系統。 VS Code 擁有大量針對多種程式語言的擴展,可以輕鬆編寫

在PHP API中說明JSON Web令牌(JWT)及其用例。 在PHP API中說明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

php程序在字符串中計數元音 php程序在字符串中計數元音 Feb 07, 2025 pm 12:12 PM

字符串是由字符組成的序列,包括字母、數字和符號。本教程將學習如何使用不同的方法在PHP中計算給定字符串中元音的數量。英語中的元音是a、e、i、o、u,它們可以是大寫或小寫。 什麼是元音? 元音是代表特定語音的字母字符。英語中共有五個元音,包括大寫和小寫: a, e, i, o, u 示例 1 輸入:字符串 = "Tutorialspoint" 輸出:6 解釋 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。總共有 6 個元

您如何在PHP中解析和處理HTML/XML? 您如何在PHP中解析和處理HTML/XML? Feb 07, 2025 am 11:57 AM

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

解釋PHP中的晚期靜態綁定(靜態::)。 解釋PHP中的晚期靜態綁定(靜態::)。 Apr 03, 2025 am 12:04 AM

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

什麼是PHP魔術方法(__ -construct,__destruct,__call,__get,__ set等)並提供用例? 什麼是PHP魔術方法(__ -construct,__destruct,__call,__get,__ set等)並提供用例? Apr 03, 2025 am 12:03 AM

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。

什麼是跨站點偽造(CSRF),您如何在PHP中實施CSRF保護? 什麼是跨站點偽造(CSRF),您如何在PHP中實施CSRF保護? Apr 07, 2025 am 12:02 AM

在PHP中可以通過使用不可預測的令牌來有效防範CSRF攻擊。具體方法包括:1.生成並在表單中嵌入CSRF令牌;2.在處理請求時驗證令牌的有效性。

See all articles