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

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

如何利用PHP中的Session

如何利用PHP中的Session,相信很多沒有經(jīng)驗(yàn)的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

創(chuàng)新互聯(lián)是一家專注于網(wǎng)站建設(shè)、做網(wǎng)站與策劃設(shè)計,嘉魚網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10多年,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:嘉魚等地區(qū)。嘉魚做網(wǎng)站價格咨詢:13518219792

0x00 前言

最近刷題碰到好幾個關(guān)于php代碼審計中session相關(guān)的問題,之前沒有做過系統(tǒng)的總結(jié),在此補(bǔ)一下鍋。

0x01 Session基礎(chǔ)知識

這里主要講講傳統(tǒng)的PHP中的“服務(wù)端Session”。至于什么是服務(wù)端Session,什么是客戶端Session,可以看看P神的**客戶端 session 導(dǎo)致的安全問題https://www.leavesongs.com/PENETRATION/client-session-security.html

Session概念:在計算機(jī)中,尤其是在網(wǎng)絡(luò)應(yīng)用中,稱為“會話控制”。Session 對象存儲特定用戶會話所需的屬性及配置信息。這樣,當(dāng)用戶在應(yīng)用程序的 Web 頁之間跳轉(zhuǎn)時,存儲在 Session 對象中的變量將不會丟失,而是在整個用戶會話中一直存在下去。當(dāng)用戶請求來自應(yīng)用程序的 Web 頁時,如果該用戶還沒有會話,則 Web 服務(wù)器將自動創(chuàng)建一個 Session 對象。當(dāng)會話過期或被放棄后,服務(wù)器將終止該會話。

Session機(jī)制:session內(nèi)容一般以文件的形式存儲于服務(wù)器中,而本地瀏覽器會存儲一個與服務(wù)器中session文件對應(yīng)的Cookie值,Cookie存儲的是鍵值為“PHPSESSID”的Seeion_id值,用戶在訪問web應(yīng)用時,每次跳轉(zhuǎn)發(fā)生http請求時,會自動把這個存儲session_id的Cookie值發(fā)送過去,因此web應(yīng)用的所有頁面都可以獲取到這個SESSION_ID值,也就可以通過session_id獲取服務(wù)器中存儲的session值,當(dāng)用戶關(guān)閉瀏覽器后,cookie存儲的session_id自動清除,一般服務(wù)器存儲的session文件也會在30分鐘后自動清除。

比如在wamp環(huán)境下,index.php如下:



如何利用PHP中的Session

首先理解一下session_start()

當(dāng)會話自動開始或者通過 session_start() 手動開始的時候, PHP 內(nèi)部會依據(jù)客戶端傳來的PHPSESSID來獲取現(xiàn)有的對應(yīng)的會話數(shù)據(jù)(即session文件), PHP 會自動反序列化session文件的內(nèi)容,并將之填充到 $_SESSION 超級全局變量中。如果不存在對應(yīng)的會話數(shù)據(jù),則創(chuàng)建名為sess_PHPSES SID(客戶端傳來的)的文件。如果客戶端未發(fā)送PHPSESSID,則創(chuàng)建一個由32個字母組成的PHPSESSID,并返回set-cookie。

可以看到請求中對應(yīng)的PHPSESSID:ifrvi9r7ui81r0fjq569b06862

在服務(wù)器端,即/wamp/tmp下我們就可以發(fā)現(xiàn)一個生成的記錄Session的文件,因?yàn)橐矝]有記錄什么會話信息,因此該文件是一個空文件。

如何利用PHP中的Session

補(bǔ)充一下關(guān)于php-Session相關(guān)配置的說明

在php.ini中對Session存在許多配置,這里我們通過phpinfo來說明幾個重要的點(diǎn)。

如何利用PHP中的Session

說明如下:



session.save_path=""  --設(shè)置session的存儲路徑session.save_handler="" --設(shè)定用戶自定義存儲函數(shù),如果想使用PHP內(nèi)置會話存儲機(jī)制之外的可以使用本函數(shù)(數(shù)據(jù)庫等方式),默認(rèn)files以文件存儲session.auto_start  boolen --指定會話模塊是否在請求開始時啟動一個會話,默認(rèn)為0不啟動session.serialize_handler  string --定義用來序列化/

常見的php-session存放位置

  1. /var/lib/php5/sess_PHPSESSID

  2. /var/lib/php7/sess_PHPSESSID

  3. /var/lib/php/sess_PHPSESSID

  4. /tmp/sess_PHPSESSID

  5. /tmp/sessions/sess_PHPSESSED

0x02 Session可能導(dǎo)致的攻擊面

  • Session序列化攻擊

  • Session文件包含

  • Session偽造用戶登錄

  • Session邏輯漏洞

0x03 Session序列化攻擊

Serialize_handler

要了解Session序列化攻擊,先來了解一下Session機(jī)制中對序列化是如何處理的。

在php中存在三種序列化處理引擎

session.serialize_handler對應(yīng)存儲格式php鍵名 + 豎線 + 經(jīng)過serialize()函數(shù)序列化處理的值php_binary鍵名的長度對應(yīng)的ASCII字符 + 鍵名 + 經(jīng)過serialize()函數(shù)序列化處理的值php_serialize( php >= 5.5.4 )經(jīng)過serialize()函數(shù)序列化處理的數(shù)組

本地測試如下:

如何利用PHP中的Session

Session文件內(nèi)容分別對應(yīng)結(jié)果為



test|s:7:"CoCo1er";<0x04>tests:7:"CoCo1er";a:1:{s:4:"test";s:7:"CoCo1er";}

攻擊利用原理

payload千萬條,原理第一條。

(這里補(bǔ)充說一點(diǎn),PHP中的Session的實(shí)現(xiàn)是沒有的問題,危害主要是由于程序員的Session使用不當(dāng)而引起的。如下)

使用不同引擎來處理session文件

如果在PHP在反序列化存儲的$_SESSION數(shù)據(jù)時使用的引擎和序列化使用的引擎不一樣,會導(dǎo)致數(shù)據(jù)無法正確第反序列化。通過精心構(gòu)造的數(shù)據(jù)包,就可以繞過程序的驗(yàn)證或者是執(zhí)行一些系統(tǒng)的方法。例如:

在這么一種情況下:

假如我們使用php_serialize引擎時進(jìn)行數(shù)據(jù)存儲時的序列化,可以得到內(nèi)容



$_SESSION[‘key’] = ‘Boby’;a:1:{s:3:”key”;s:4:”Boby”;}

這時我們的解析采用了另一種引擎:php

思考一下這時會發(fā)生什么情況?(php引擎中以豎線來分隔鍵和值)

如果像上面我們的payload換一下,傳入內(nèi)容以及得到的存儲內(nèi)容如下:



$_SESSION['key'] = '|O:4:"User":0:{}';a:1:{s:3:"key";s:16:"|O:4:"User":0:{}";}

這時候a:1:{s:3:"key";s:16:"被當(dāng)作了key,

而后續(xù)的O:4:"User":0:{}";}被當(dāng)作了value從而被反序列化。這里可能有人會問了,為什么會被反序列化?

看看官方文檔

如何利用PHP中的Session

這里可能還會有人問?那串value不符合"正常"的被反序列化的字符串規(guī)則。這個也不用擔(dān)心,這里提到一個unserialize的特性,之前也做題也遇到過。在執(zhí)行unserialize的時候,如果字符串前面滿足了可被反序列化的規(guī)則即后續(xù)的不規(guī)則字符會被忽略。

如果不太好理解不如直接來看一個在線測試用例:

如何利用PHP中的Session

總結(jié)一下,在php以php_serialize引擎生成session,然而又以php引擎來解析時,我們通過傳入類似$_SESSION[‘name’] = |序列化內(nèi)容 這種形式的payload即有可能觸發(fā)反序列化漏洞。當(dāng)然這里只是提到了能夠找到反序列化利用的點(diǎn),至于能不能真正觸發(fā)反序列化漏洞還需要結(jié)合當(dāng)前環(huán)境以及一些魔術(shù)函數(shù)中是否存在可利用點(diǎn)。這就涉及到php反序列化漏洞的利用知識點(diǎn)了,這里也就不詳細(xì)講了。關(guān)于Session反序列化攻擊的復(fù)雜利用方式,可以參考2018LCTF中的bestphp’s revenge一題。

沒有$_SESSION變量賦值

從上面的情況中我們可以發(fā)現(xiàn)我們對session的賦值可控。那如果代碼中不存在對$_SESSION變量賦值的情況下如何利用呢?來看下面一個點(diǎn)。

php還存在一個upload_process機(jī)制,即自動在$_SESSION中創(chuàng)建一個鍵值對,值中剛好存在用戶可控的部分。

寫入的方式主要是利用PHP中Session Upload Progress來進(jìn)行設(shè)置,具體為,在上傳文件時,如果POST一個名為PHP_SESSION_UPLOAD_PROGRESS的變量,就可以將filename的值賦值到session中。



//上傳表單

                                   
既然filename字段能夠?qū)懭雜ession中那么就滿足了session可控條件,后續(xù)的利用條件同上面所述的情景一致,兩種不同引擎先后作用導(dǎo)致了惡意的序列化字符串被解析。

0x04 Session文件包含

這個也是一個比較舊的知識點(diǎn)了,其實(shí)不僅是Session文件包含,仔細(xì)想想,理論上只要能夠在文件中寫入php代碼,再被include包含進(jìn)來不都可以實(shí)現(xiàn)getshell嘛?只不過在這里我們的可控點(diǎn)是Session文件,如果能向其中寫入php代碼,也是可以實(shí)現(xiàn)文件包含漏洞利用的。

作為文件包含的利用這里就不展示了,網(wǎng)上關(guān)于這個的基礎(chǔ)資料早就爛大街了。

值得一提的是,往往現(xiàn)在的CTF出題不會僅限于文件包含這一個點(diǎn)來出題,而是利用諸如session+lfi的形式來入題獲取源碼等。而且可能加入open_basedir來限制路徑,此時就需要熟悉了解session的機(jī)制,通過函數(shù)來改變save路徑來利用。這個思路是在XCTF Final中出現(xiàn)的bestphp一題中的考點(diǎn)。感興趣的同學(xué)可以去找到環(huán)境復(fù)現(xiàn)一波。

0x05 Session偽造用戶登錄

前幾天正好3CTF出了一個這個考點(diǎn),這里以那個題目來說明一下利用方式。(由于沒有提供復(fù)現(xiàn)環(huán)境,此處也只能限于“紙上談兵”,希望大家能夠理解一下利用原理即可。)

**利用前提:**session可控;知道session存儲格式。

這里的考題是多個攻擊面的組合。題面index.php下提示要以admin登錄。

  • sql盲注可以跑sqlmap拿到執(zhí)行shell

  • sql root用戶存在file權(quán)限,但是往站點(diǎn)直接寫shell無法成功(猜測應(yīng)該是站點(diǎn)根目錄有限制,但是可以猜測/tmp可寫

  • 掃后臺發(fā)現(xiàn)test.php,訪問發(fā)現(xiàn)回顯了session的數(shù)據(jù)結(jié)構(gòu)Array([username]=>test),知道了session的格式。key為username,至于采用了哪種序列化引擎?三種都測一下就完事。

  • 這里滿足了兩個利用前提。通過sqlmap-shell往/tmp寫入文件偽造admin

  • payload:select 'username|s:5:"admin";' into outfile '/tmp/sess_PHPSESSID'

  • 最后修改成對應(yīng)設(shè)計的PHPSESSID即可偽造admin登錄拿到flag。

0x06 Session邏輯漏洞

很遺憾這個點(diǎn)也沒有可以復(fù)現(xiàn)的環(huán)境。(官方買斷...)這個是上兩周unctf中出現(xiàn)的一道web題考點(diǎn)。這個邏輯漏洞處在重置密碼處。過程大致如下。

密碼重置分為三個步驟。

  • 填寫需要重置的用戶名

  • 用戶名綁定的郵箱中收到驗(yàn)證碼

  • 填寫驗(yàn)證碼,進(jìn)入重置密碼頁面,填寫完新密碼完成重置。

這里存在的邏輯漏洞在于第一個頁面的填寫用戶名處,猜測后臺有設(shè)置session。類似:

$_SESSION[‘name’] = $_POST['name'];

利用方式:重置admin密碼。

  • 打開一個正常頁面完整流程走到最后一步,填寫完驗(yàn)證碼通過后,填寫新密碼,此時并不提交。

  • 新開另外一個頁面完成第一步,重置用戶填寫admin,此時Session不再是我們之前自己的用戶,而變成了admin。

  • 這時完成之前頁面的提交。成功重置admin密碼。

這里邏輯漏洞產(chǎn)生的原因在于對填寫驗(yàn)證碼后沒有對相關(guān)用戶綁定做記錄,在最后一步重置密碼時沒有對Session的可靠性進(jìn)行檢查就直接執(zhí)行了功能。而我們都知道Session存儲在服務(wù)器端,因此我們再開一個頁面即可完成對單一session文件內(nèi)容的修改(保證在同一個PHPSEEID下)。

這里僅僅是記錄了自己關(guān)于PHP的session機(jī)制相關(guān)的學(xué)習(xí),舉的都是自己最近在CTF題中接觸到的點(diǎn),但關(guān)于session的利用點(diǎn)怎么可能只有這幾個?遇到了再補(bǔ)充學(xué)習(xí)吧。限于篇幅沒有展開講拓展利用,但是說白了,拓展利用就是多個復(fù)雜知識點(diǎn)的綜合。我認(rèn)為只有把原理性的問題搞清楚了才有可能去理解復(fù)雜的組合攻擊。另外如果文中有什么理解表達(dá)錯誤的地方還望師傅們指正。

看完上述內(nèi)容,你們掌握如何利用PHP中的Session的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!


網(wǎng)站標(biāo)題:如何利用PHP中的Session
文章源于:http://weahome.cn/article/piiphe.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部