[安洵杯 2019]easy_serialize_php之愚見

三句題外話,第一句是終于放假了,在考試周活了下來,最后一周面臨3門考試,我仍然做了2道比較基礎(chǔ)的題目,現(xiàn)在重做一下順便寫wp,不敢說是熱愛,勉強(qiáng)說是興趣,矢志web。第二句是感謝通信原理老師給了我過,對(duì)于從沒接觸過通信的我來說,上課完全聽不懂,最后靠黨性,衷心感謝老師。第三句,寒假還是要學(xué)點(diǎn)習(xí)的(坐等真香),尤其是追求自己的喜歡的。

進(jìn)入正題,打開即是源碼,

將參數(shù)f改成phpinfo即可調(diào)用phpinfo()函數(shù),看到幾個(gè)比較敏感的點(diǎn),

我想到了幾個(gè)問題:

1.源碼里,沒有session_start(),phpinfo()里,session.auto_start也是off的,這樣的話,在session這個(gè)問題上,每個(gè)頁面頂多只能讀取本身頁面的$_SESSION數(shù)組。所以對(duì)于本題來講應(yīng)該只需要對(duì)這個(gè)頁面做文章,不用想別的頁面了。我們要搞清楚PHP中session機(jī)制的工作流程,同時(shí)我們也要明白這個(gè)題目里根本沒有讀取session文件,這個(gè)題只是把$_SESSION數(shù)組進(jìn)行了serialize(),這種地方不要因?yàn)榭吹絧hp處理器而犯迷糊。

2.雖然使用的是php處理器,但按上面所講顯然不存在解析器差異帶來的對(duì)象注入問題;

3.過濾函數(shù)filter()是對(duì)serialize($_SESSION)進(jìn)行過濾,濾掉一些關(guān)鍵字

4.正常傳img參數(shù)進(jìn)去會(huì)被sha1加密,我認(rèn)為這里應(yīng)該不存在有一個(gè)字符串,它sha1加密后的結(jié)果能與dog_flag.php這種名字碰撞,故我們應(yīng)該用別的方法控制$_SESSION中的參數(shù);

5.引用一位大佬的一句話:任何具有一定結(jié)構(gòu)的數(shù)據(jù),只要經(jīng)過了某些處理而把自身結(jié)構(gòu)改變,則可能會(huì)產(chǎn)生漏洞。

本來挺好的序列化的字符串,按某種去掉了一些關(guān)鍵字,本身就不對(duì),本身就涉及到可能破壞原有結(jié)構(gòu)而無法正常反序列化的問題。這里是利用反序列化長度逃逸控制了img參數(shù)。之前有一道題目是關(guān)鍵字替換導(dǎo)致字符串長度變長,把后面的原有參數(shù)擠出去了,本題是關(guān)鍵字被置空導(dǎo)致長度變短,后面的值的單引號(hào)閉合了前面的值的單引號(hào),導(dǎo)致一些內(nèi)容逃逸。


正常的序列化字符串

因?yàn)槲覀兡芸刂频氖?_SESSION的參數(shù),payload只能以字符串形式傳進(jìn)去,然后想辦法將它前面的控制符? s:xx: 閉合到一個(gè)字符串中取,這樣就能將后面的payload作為獨(dú)立的一個(gè)鍵和值。

我們需要的序列化字符串的格式(為了便于截圖已換行)

我們要注意一點(diǎn),如果 s:40:被閉合了,前面的s:5:"xxxxx";s:40:"只是一個(gè)鍵,而沒有值(先不考慮長度問題),會(huì)反序列化失敗,所以我們的payload的里應(yīng)額外包含一個(gè)鍵值對(duì),


真正能發(fā)揮作用的字符串的格式

";s:64: 這幾個(gè)控制字符長度為7,";s:7:"xxxxxxx"這幾個(gè)控制字符(和數(shù)據(jù))長度為13,為了將他們閉合進(jìn)前面的字符串,


由外而內(nèi)


由此以來的話,payload為

;s:14:"phpflagphpflag";s:7:"xxxxxxx";s:3:"img";s:20:"L2QwZzNfZmxsbGxsbGFn";}

傳入即可,


心得:接觸一個(gè)題時(shí)思路還是要發(fā)散的,通過題目去猜測出題人的引導(dǎo),去排除,再加上多多積累多多見識(shí)多多實(shí)踐,(不難的)題目一般都可以做。不得不說安洵杯的題確實(shí)比較友好,考點(diǎn)不難而且也比較直接,不拐彎抹角。

大膽應(yīng)無懼,雄心誓不回

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,431評(píng)論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,637評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,555評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,900評(píng)論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,629評(píng)論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,976評(píng)論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,976評(píng)論 3 448
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,139評(píng)論 0 290
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,686評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,411評(píng)論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,641評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,129評(píng)論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,820評(píng)論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,233評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,567評(píng)論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,362評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,604評(píng)論 2 380

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

  • sqlmap用戶手冊 說明:本文為轉(zhuǎn)載,對(duì)原文中一些明顯的拼寫錯(cuò)誤進(jìn)行修正,并標(biāo)注對(duì)自己有用的信息。 ======...
    wind_飄閱讀 2,077評(píng)論 0 5
  • http://192.168.136.131/sqlmap/mysql/get_int.php?id=1 當(dāng)給sq...
    xuningbo閱讀 10,387評(píng)論 2 22
  • 4.1.1. 后門 4.1.1.1. php.ini構(gòu)成的后門 ??利用 auto_prepend_file 和 ...
    最酷的崽_ec69閱讀 590評(píng)論 0 0
  • 11、談?wù)刴vc的認(rèn)識(shí)。由模型、視圖、控制器完成的應(yīng)用程序,由模型發(fā)出要實(shí)現(xiàn)的功能到控制器,控制器接收組織功能傳遞...
    像敏銳的狗閱讀 397評(píng)論 0 2
  • 今天是早就劃算好了的,不去健身房。算著有這么多的時(shí)間,可以寫一段文字,可以看很多頁的書,還有聽好幾課的課程了。 然...
    最早的花拖鞋閱讀 2,939評(píng)論 17 233