中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP安全防護之Web攻擊的示例分析

發布時間:2021-08-09 09:58:19 來源:億速云 閱讀:147 作者:小新 欄目:開發技術

這篇文章主要為大家展示了“PHP安全防護之Web攻擊的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“PHP安全防護之Web攻擊的示例分析”這篇文章吧。

SQL注入攻擊(SQL Injection)

攻擊者把SQL命令插入到Web表單的輸入域或頁面請求的字符串,欺騙服務器執行惡意的SQL命令。在某些表單中,用戶輸入的內容直接用來構造(或者影響)動態SQL命令,或作為存儲過程的輸入參數,這類表單特別容易受到SQL注入式攻擊。

常見的SQL注入式攻擊過程類如:

1.某個Web應用有一個登錄頁面,這個登錄頁面控制著用戶是否有權訪問應用,它要求用戶輸入一個名稱和密碼;

2.登錄頁面中輸入的內容將直接用來構造動態的SQL命令,或者直接用作存儲過程的參數;

例如:

$query = 'SELECT * from Users WHERE login = ' . $username . ' AND password = ' . $password;

3.攻擊者在用戶名字和密碼輸入框中輸入'或'1'='1之類的內容;

4.用戶輸入的內容提交給服務器之后,服務器運行上面的代碼構造出查詢用戶的SQL命令,但由于攻擊者輸入的內容非常特殊,所以最后得到的SQL命令變成:

SELECT * from Users WHERE login = '' or '1'='1' AND password = '' or '1'='1';

5.服務器執行查詢或存儲過程,將用戶輸入的身份信息和服務器中保存的身份信息進行對比;

6.由于SQL命令實際上已被注入式攻擊修改,已經不能真正驗證用戶身份,所以系統會錯誤地授權給攻擊者。

如果攻擊者知道應用會將表單中輸入的內容直接用于驗證身份的查詢,他就會嘗試輸入某些特殊的SQL字符串篡改查詢改變其原來的功能,欺騙系統授予訪問權限。

系統環境不同,攻擊者可能造成的損害也不同,這主要由應用訪問數據庫的安全權限決定。如果用戶的帳戶具有管理員或其他比較高級的權限,攻擊者就可能對數據庫的表執行各種他想要做的操作,包括添加、刪除或更新數據,甚至可能直接刪除表

防范方法:

      1.檢查變量數據類型和格式

      2.過濾特殊符號

      3.綁定變量,使用預編譯語句

跨網站腳本攻擊(Cross Site Scripting, XSS)

攻擊者將惡意代碼注入到網頁上,其他用戶在加載網頁時就會執行代碼,攻擊者可能得到包括但不限于更高的權限(如執行一些操作)、私密網頁內容、會話和cookie等各種內容。這些惡意代碼通常是JavaScript、HTML以及其他客戶端腳本語言。
例如:

<?php
echo "歡迎您,".$_GET['name'];

如果傳入一段腳本<script>[code]</script> ,那么腳本也會執行。用這樣的URL將會執行JavaScript的alert函數彈出一個對話框:http://localhost/test.php?name=<script>alert(123456)</script>

常用的攻擊手段有:

盜用cookie,獲取敏感信息;

利用iframe、frame、XMLHttpRequest或上述Flash等方式,以(被攻擊)用戶的身份執行一些管理動作,或執行一些一般的如發微博、加好友、發私信等操作;

利用可被攻擊的域受到其他域信任的特點,以受信任來源的身份請求一些平時不允許的操作,如進行不當的投票活動;

在訪問量極大的一些頁面上的XSS可以攻擊一些小型網站,實現DDoS攻擊的效果。

防范方法:使用htmlspecialchars函數將特殊字符轉換成HTML編碼,過濾輸出的變量

跨網站請求偽造攻擊(Cross Site Request Forgeries, CSRF)

攻擊者偽造目標用戶的HTTP請求,然后此請求發送到有CSRF漏洞的網站,網站執行此請求后,引發跨站請求偽造攻擊。攻擊者利用隱蔽的HTTP連接,讓目標用戶在不注意的情況下單擊這個鏈接,由于是用戶自己點擊的,而他又是合法用戶擁有合法權限,所以目標用戶能夠在網站內執行特定的HTTP鏈接,從而達到攻擊者的目的。

它與XSS的攻擊方法不同,XSS利用漏洞影響站點內的用戶,攻擊目標是同一站點內的用戶者,而CSRF 通過偽裝成受害用戶發送惡意請求來影響Web系統中受害用戶的利益。

例如:

某個購物網站購買商品時,采用http://www.shop.com/buy.php?item=watch&num=100,item參數確定要購買什么物品,num參數確定要購買數量,如果攻擊者以隱藏的方式發送給目標用戶鏈接
,那么如果目標用戶不小心訪問以后,購買的數量就成了100個

防范方法:

      1、檢查網頁的來源

      2、檢查內置的隱藏變量

      3、使用POST,不要使用GET,處理變量也不要直接使用$_REQUEST

Session固定攻擊(Session Fixation)

這種攻擊方式的核心要點就是讓合法用戶使用攻擊者預先設定的session id來訪問被攻擊的應用程序,一旦用戶的會話ID被成功固定,攻擊者就可以通過此session id來冒充用戶訪問應用程序。

例如:

1.攻擊者訪問網站http:///www.bank.com,獲取他自己的session id,如:SID=123;

2.攻擊者給目標用戶發送鏈接,并帶上自己的session id,如:http:///www.bank.com/?SID=123;

3.目標用戶點擊了http:///www.bank.com/?SID=123,像往常一樣,輸入自己的用戶名、密碼登錄到網站;

4.由于服務器的session id不改變,現在攻擊者點擊http:///www.bank.com/?SID=123,他就擁有了目標用戶的身份,可以為所欲為了。

防范方法:

1.定期更改session id

session_regenerate_id(TRUE);//刪除舊的session文件,每次都會產生一個新的session id。默認false,保留舊的session

2.更改session的名稱

session的默認名稱是PHPSESSID,此變量會保存在cookie中,如果攻擊者不抓包分析,就不能猜到這個名稱,阻擋部分攻擊

session_name("mysessionid");

3.關閉透明化session id

透明化session id指當瀏覽器中的http請求沒有使用cookie來制定session id時,sessioin id使用鏈接來傳遞

int_set("session.use_trans_sid", 0);

4.只從cookie檢查session id

int_set("session.use_cookies", 1);//表示使用cookies存放session id
int_set("session.use_only_cookies", 1);//表示只使用cookies存放session id

5.使用URL傳遞隱藏參數

$sid = md5(uniqid(rand()), TRUE));
$_SESSION["sid"] = $sid;//攻擊者雖然能獲取session數據,但是無法得知$sid的值,只要檢查sid的值,就可以確認當前頁面是否是web程序自己調用的

Session劫持攻擊(Session Hijacking)

會話劫持是指攻擊者利用各種手段來獲取目標用戶的session id。一旦獲取到session id,那么攻擊者可以利用目標用戶的身份來登錄網站,獲取目標用戶的操作權限。

攻擊者獲取目標用戶session id的方法:

1.暴力破解:嘗試各種session id,直到破解為止;

2.計算:如果session id使用非隨機的方式產生,那么就有可能計算出來;

3.竊取:使用網絡截獲,xss攻擊等方法獲得

防范方法:

      1.定期更改session id

      2.更改session的名稱

      3.關閉透明化session id

      4.設置HttpOnly。通過設置Cookie的HttpOnly為true,可以防止客戶端腳本訪問這個Cookie,從而有效的防止XSS攻擊。

文件上傳漏洞攻擊(File Upload Attack)

文件上傳漏洞指攻擊者利用程序缺陷繞過系統對文件的驗證與處理策略將惡意代碼上傳到服務器并獲得執行服務器端命令的能力。

常用的攻擊手段有:

上傳Web腳本代碼,Web容器解釋執行上傳的惡意腳本;

上傳Flash跨域策略文件crossdomain.xml,修改訪問權限(其他策略文件利用方式類似);

上傳病毒、木馬文件,誘騙用戶和管理員下載執行;

上傳包含腳本的圖片,某些瀏覽器的低級版本會執行該腳本,用于釣魚和欺詐。

總的來說,利用的上傳文件要么具備可執行能力(惡意代碼),要么具備影響服務器行為的能力(配置文件)。

防范方法:

      1.文件上傳的目錄設置為不可執行;

      2.判斷文件類型,設置白名單。對于圖片的處理,可以使用壓縮函數或者resize函數,在處理圖片的同時破壞圖片中可能包含的HTML代碼;

      3.使用隨機數改寫文件名和文件路徑:一個是上傳后無法訪問;再來就是像shell.php.rar.rar和crossdomain.xml這種文件,都將因為重命名而無法攻擊;

      4.單獨設置文件服務器的域名:由于瀏覽器同源策略的關系,一系列客戶端攻擊將失效,比如上傳crossdomain.xml、上傳包含Javascript的XSS利用等問題將得到解決。

以上是“PHP安全防護之Web攻擊的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

澳门| 文水县| 海伦市| 盐山县| 东辽县| 新化县| 扶绥县| 南召县| 合山市| 潞城市| 黑水县| 莱西市| 南华县| 建始县| 文水县| 广汉市| 亚东县| 丽水市| 商丘市| 遂溪县| 中西区| 抚顺县| 南丰县| 荣成市| 余干县| 林芝县| 定襄县| 常山县| 乌拉特中旗| 临潭县| 攀枝花市| 北碚区| 上思县| 资兴市| 阜南县| 邵阳市| 浙江省| 东光县| 咸丰县| 新疆| 石屏县|