真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯網站制作重慶分公司

web服務器怎么做好上傳漏洞安全-創(chuàng)新互聯

web服務器怎么做好上傳漏洞安全【199cloud-艾娜】

Web應用程序通常會有文件上傳的功能,例如,在BBS發(fā)布圖片、在個人網站發(fā)布Zip壓縮包、在招聘網站上發(fā)布DOC格式簡歷等。只要Web應用程序允許上傳文件,就有可能存在文件上傳漏洞。

創(chuàng)新互聯是一家專注于網站制作、成都網站制作與策劃設計,陸川網站建設哪家好?創(chuàng)新互聯做網站,專注于網站建設10余年,網設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:陸川等地區(qū)。陸川做網站價格咨詢:13518219792

1. 解析漏洞

攻擊者在利用上傳漏洞時,通常會與Web容器(IIS、Nginx、Apache、Tomc等at)的解析漏洞配合在一起

  • IIS解析漏洞:當建立 *.asa、*.asp格式的文件夾時,其目錄下的任意文件都將被IIS當作asp文件來解析,在瀏覽器打開文件時,內容就會直接暴漏在瀏覽器里,上傳的話,危險腳本就會運行起來,達到攻擊的目的;
    如: http://127.0.0.1/parsing.asp/test.txt

  • Apache解析漏洞;

  • PHP CGI解析漏洞;

2. 繞過上傳漏洞

程序員在防止上傳漏洞時可以分為以下兩種:

  • 客戶端檢測:客戶端使用JavaScript檢測,在文件未上傳時,就對文件進行驗證;
    因此,繞過客戶端的檢測來達到攻擊的方式有以下兩種:

(1)使用FireBug:找到html源代碼里面的Form表單,將onsubmit事件刪除,JavaScript上傳驗證將會失效。
(2)中間人攻擊:使用Burb Suite則是按照正常的流程通過JavaScript驗證,然后在傳輸中的HTTP層做手腳。( 在上傳時使用Burb Suite攔截上傳數據,修改文件擴展名,就可以繞過客戶端驗證)。

注意:任何客戶端驗證都是不安全的??蛻舳蓑炞C是防止用戶輸入錯誤,減少服務器開銷,而服務器端驗證才可以真正防御攻擊者。

  • 服務端檢測:服務端腳本一般會檢測文件的MIME類型,檢測文件擴展名是否合法,甚至有些程序員檢測文件中是否嵌入惡意代碼。
    主要有以下幾種,但也有存在漏洞的可能:

(1)白名單與黑名單驗證
在上傳文件時,大多數程序員會對文件擴展名檢測,驗證文件擴展名通常有兩種方式:白名單與黑名單。

黑名單過濾方式:是一種不安全的過濾方式,黑名單定義了一系列不允許上傳的文件的擴展名,服務器端接收文件后,與黑名單擴展名對比,如果發(fā)現文件擴展名與黑名單里的擴展名匹配,則認為文件不合法。舉例子:

$BlackList = array('asp', 'php', 'jsp', 'php5', 'asa', 'aspx'); // 黑名單//然而并不能很好的防御: .cer文件并沒有在黑名單里,則,可以通過驗證,因此是無法防御上傳漏洞的。

白名單過濾方式:與黑名單恰恰相反,定義一系列允許上傳的擴展名,白名單擁有比黑名單更好的防御機制。舉例子:

$WhiteList = array('rar', 'jpg', 'png', 'bmp', 'gif', 'doc'); // 白名單// 然而并不能很好的防御:// 例如:Web容器為IIS 6.0,攻擊者把木馬文件改名為pentest.asp;1.jpg上傳,此時的文件為jpg格式,從而可以順利通過驗證,而IIS 6.0卻會把pentest.asp;1.jpg當作asp腳本程序來執(zhí)行,最終攻擊者可以繞過白名單的檢測,并且執(zhí)行木馬程序。// 白名單機制僅僅是防御上傳漏洞的第一步。

(2)MIME驗證
MIME類型用來設定某種擴展名文件的打開方式,當具有該擴展名的文件被訪問時,瀏覽器會自動使用指定的應用程序來打開。如GIF圖片MIME為image/gif,css文件MIME類型為text/css。

// 開發(fā)人員經常會對文件MIME類型做驗證,PHP代碼如下:if ($_FILES['file']['type'] == 'image/jpg'){ // 判斷是否是jpg格式
    // ...}

因此,如果上傳PHP文件時,并使用Burp Suite攔截查看MIME類型,可以發(fā)現PHP文件的MIME類型為 application/php,而上面代碼中會判斷文件類型是否為image/jpg,顯然這里無法通過驗證。
但是在攔截的時候可以將HTTP請求中的content-Type更改為image/jpg類型,這樣即可通過程序驗證,達到攻擊的目的。

(3)目錄驗證
再文件上傳時,程序員通常允許用戶將文件放到指定的目錄中,然而有些Web開發(fā)人員為了讓代碼更“健壯”,通常會做一個動作,如果指定的目錄存在,就將文件寫入目錄中,不存在則先建立目錄,然后再寫入文件。

攻擊方式:通過使用工具將普通的文件夾名稱改為 .asp格式的目錄,稱為 畸形文件夾,然后提交 一句話圖片木馬文件,即上傳成功后,這個網頁木馬就會被解析,從而使下攻擊。

(4)截斷上傳攻擊
也是使用工具進行攔截更改。
截斷上傳攻擊在ASP程序中最常見,在PHP、JSP也會存在這樣的攻擊問題。

3. 文本編輯器上傳漏洞

常見的文本編輯器有CKEditor、Ewebeditor、UEditor、KindEditor、XHeditor等。這類編輯器的功能都是非常類似的,比如都有圖片上傳、視頻上傳、遠程下載等功能,這類文本編輯器也稱為副文本編輯器。

使用此類編輯器減少了程序開發(fā)的時間,但是卻增加了許多安全隱患,比如: 使用CKEditor編輯器的有10萬個網站,如果CKEditor爆出一個GetShell漏洞,那么著10萬個網站都因此受到牽連。主要的漏洞體現在以下幾種:
(1)敏感信息暴露。
(2)黑名單策略錯誤:黑名單有漏掉的擴展名。
(3)使用Burp Suite攔截修改,達到任意文件都可以上傳。


當前文章:web服務器怎么做好上傳漏洞安全-創(chuàng)新互聯
網頁URL:http://weahome.cn/article/jgpic.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部