任意文件上傳與下載(文件上傳)

上傳文件

后臺開發(fā)時并沒有對上傳的文件進(jìn)行安全考慮或采用了有缺陷的措施菩佑,導(dǎo)致攻擊者可以通過一些手段繞過安全措施從而上傳一些惡意文件,從而通過該惡意文件的訪問來控制整個后臺

文件上傳靶機(jī)下載地址:https://github.com/c0ny1/upload-labs

一地回、測試流程:


vstart webshell里面找php


在pikachu上傳文件選擇路徑找到123.jpg

上傳成功


如果擴(kuò)展名不是.jpg?? 上傳不成功,不允許上傳

檢查源代碼有函數(shù)

客戶端繞過

方法一:刪掉函數(shù)(沒成功)


方法二:burpsuite抓包(不受客戶端限制)



發(fā)送? 200成功


傳輸之后 render看一下顯示剛剛改完擴(kuò)展名的.php文件

代理 攔截禁用 放行

服務(wù)端

2俊鱼、服務(wù)端驗(yàn)證繞過(MIME 類型檢測)

? ? ? MIME(Multipurpose Internet Mail Extensions)多用途互聯(lián)網(wǎng)郵件擴(kuò)展類型落君。是設(shè)定某種擴(kuò)展名的文件用一種應(yīng)用程序來打開的方式類型,當(dāng)該擴(kuò)展名文件被訪問的時候亭引,瀏覽器會自動使用指定應(yīng)用程序來打開。多用于指定一些客戶端自定義的文件名皮获,以及一些媒體文件打開方式焙蚓。

? ? ? 每個MIME類型由兩部分組成,前面是數(shù)據(jù)的大類別洒宝,例如聲音audio购公、圖象image等,后面定義具體的種類雁歌。

常見的MIME類型(通用型):

超文本標(biāo)記語言文本 .html text/html

xml文檔 .xml text/xml

XHTML文檔 .xhtml application/xhtml+xml

普通文本 .txt text/plain

RTF文本 .rtf application/rtf

PDF文檔 .pdf application/pdf

Microsoft Word文件 .word application/msword

PNG圖像 .png image/png

GIF圖形 .gif image/gif

JPEG圖形 .jpeg,.jpg image/jpeg

au聲音文件 .au audio/basic

MIDI音樂文件 mid,.midi audio/midi,audio/x-midi

RealAudio音樂文件 .ra, .ram audio/x-pn-realaudio

MPEG文件 .mpg,.mpeg video/mpeg

AVI文件 .avi video/x-msvideo

GZIP文件 .gz application/x-gzip

TAR文件 .tar application/x-tar

任意的二進(jìn)制數(shù)據(jù) application/octet-stream

? ? 通過使用 PHP 的全局?jǐn)?shù)組 $_FILES宏浩,你可以從客戶計(jì)算機(jī)向遠(yuǎn)程服務(wù)器上傳文件。

第一個參數(shù)是表單的 input name靠瞎,第二個下標(biāo)可以是 "name", "type", "size", "tmp_name" 或 "error"比庄。就像這樣:

$_FILES["file"]["name"] - 被上傳文件的名稱

$_FILES["file"]["type"] - 被上傳文件的類型

$_FILES["file"]["size"] - 被上傳文件的大小求妹,以字節(jié)計(jì)

$_FILES["file"]["tmp_name"] - 存儲在服務(wù)器的文件的臨時副本的名稱

$_FILES["file"]["error"] - 由文件上傳導(dǎo)致的錯誤代碼

詳細(xì)可參考:http://www.w3school.com.cn/php/php_file_upload.asp

? ? ? 分析代碼邏輯:首先會獲取到前端的提交請求,然后定義了一個數(shù)組(定義圖片上傳指定類型)佳窑,然后通過upload_sick函數(shù)對上傳的文件進(jìn)行一定的檢查制恍。

分析upload_sick函數(shù)存在漏洞的的原因是因?yàn)?$ _FILES() 這個全局的方法是通過瀏覽器http頭去獲取的content-type,content-type是前端用戶可以控制的神凑。容易被繞過净神。

? ? 上傳一張正常的符合標(biāo)準(zhǔn)的圖片,對其content-type進(jìn)行抓包操作溉委【槲ǎ可見正常上傳符合要求的圖片中數(shù)據(jù)包中content-type為image/png對比符合條件,而php文件則不符合條件返回文件類型錯誤瓣喊。

文件頭上傳

抓包


改頭繞過


發(fā)送到重發(fā)器改頭? 成功繞過

getimagesize

GIF89A

文件包含

圖片能當(dāng)腳本執(zhí)行一定有包含

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末坡慌,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子型宝,更是在濱河造成了極大的恐慌八匠,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,198評論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件趴酣,死亡現(xiàn)場離奇詭異梨树,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)岖寞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評論 3 398
  • 文/潘曉璐 我一進(jìn)店門抡四,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人仗谆,你說我怎么就攤上這事指巡。” “怎么了隶垮?”我有些...
    開封第一講書人閱讀 167,643評論 0 360
  • 文/不壞的土叔 我叫張陵藻雪,是天一觀的道長。 經(jīng)常有香客問我狸吞,道長勉耀,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,495評論 1 296
  • 正文 為了忘掉前任蹋偏,我火速辦了婚禮便斥,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘威始。我一直安慰自己枢纠,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,502評論 6 397
  • 文/花漫 我一把揭開白布黎棠。 她就那樣靜靜地躺著晋渺,像睡著了一般镰绎。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上些举,一...
    開封第一講書人閱讀 52,156評論 1 308
  • 那天跟狱,我揣著相機(jī)與錄音,去河邊找鬼户魏。 笑死驶臊,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的叼丑。 我是一名探鬼主播关翎,決...
    沈念sama閱讀 40,743評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鸠信!你這毒婦竟也來了纵寝?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,659評論 0 276
  • 序言:老撾萬榮一對情侶失蹤星立,失蹤者是張志新(化名)和其女友劉穎爽茴,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體绰垂,經(jīng)...
    沈念sama閱讀 46,200評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡室奏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,282評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了劲装。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片胧沫。...
    茶點(diǎn)故事閱讀 40,424評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖占业,靈堂內(nèi)的尸體忽然破棺而出绒怨,到底是詐尸還是另有隱情,我是刑警寧澤谦疾,帶...
    沈念sama閱讀 36,107評論 5 349
  • 正文 年R本政府宣布南蹂,位于F島的核電站,受9級特大地震影響念恍,放射性物質(zhì)發(fā)生泄漏碎紊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,789評論 3 333
  • 文/蒙蒙 一樊诺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧音同,春花似錦词爬、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽锅锨。三九已至,卻和暖如春恋沃,著一層夾襖步出監(jiān)牢的瞬間必搞,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評論 1 271
  • 我被黑心中介騙來泰國打工囊咏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留恕洲,地道東北人。 一個月前我還...
    沈念sama閱讀 48,798評論 3 376
  • 正文 我出身青樓梅割,卻偏偏與公主長得像霜第,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子户辞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,435評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 任意文件上傳:簡單概述 任意文件上傳分為兩大類: 客戶端 服務(wù)端客戶端 (前端繞過):js檢查服務(wù)端(后端繞過)...
    960608fhy閱讀 151評論 0 0
  • 5泌类、任意文件下載攻擊原理及測試方法以及修復(fù)漏洞的方法:攻擊原理:網(wǎng)站由于業(yè)務(wù)需要,提供了文件查看和文件下載的功能底燎,...
    皮蛋是個臭蛋閱讀 649評論 0 0
  • 文件上傳 客戶端上傳設(shè)置 在B/S程序中文件上傳已經(jīng)成為一個常用功能刃榨。其目的是客戶可以通過瀏覽器(Browser)...
    dptms閱讀 961評論 0 0
  • 一、文件上傳 將客戶端文件上傳到服務(wù)器端双仍,再將服務(wù)器端的文件(臨時文件)移動到指定目錄即可枢希。 1、form表單 文...
    四月不見閱讀 402評論 0 6
  • 漸變的面目拼圖要我怎么拼呕屎? 我是疲乏了還是投降了? 不是不允許自己墜落敬察, 我沒有滴水不進(jìn)的保護(hù)膜秀睛。 就是害怕變得面...
    悶熱當(dāng)乘涼閱讀 4,249評論 0 13