码迷,mamicode.com
首页 > 其他好文 > 详细

xctf-pwn level3

时间:2020-03-24 10:32:30      阅读:116      评论:0      收藏:0      [点我收藏+]

标签:就是   main   作用   src   ima   bin   返回   read   函数   

这道题研究了很久,总算是理解了got表和plt表的关系和作用

checksec看防护

技术图片

main函数里提示了vunlnerable函数

技术图片

查看一下vulnerable函数

技术图片

可以利用read函数栈溢出,但是这道题没有给system函数。所以我们可以利用附件给的libc_32.so.6文件,计算出system的地址并执行/bin/sh命令

技术图片

IDA里显示的地址是plt的地址。函数被调用时会从plt表跳转到got表最后跳转到真实地址。也就是说,got表指向的是真实地址,plt表指向的是got表内的相应地址。

exp:

技术图片

libc.so 动态链接库中的函数之间相对偏移是固定的,所以只要找到基地址再加上偏移量就可以算出真实地址

1.用elf模块读取got

2.调用write函数。调用write可以把目标地址用write函数输出

3.返回地址,此处是main函数地址,返回main函数后会再执行一次vulnerable函数,这样可以实现两次溢出,第一次溢出得到write的got地址,减去libc的write的真实地址可以计算出偏移量。利用偏移量加上基地址算出system地址和/bin/sh的地址。

第二次溢出利用system函数getshell。

4.write函数的参数。

 

ps:偏移量的计算也可以用其他函数的got地址,例如read。

xctf-pwn level3

标签:就是   main   作用   src   ima   bin   返回   read   函数   

原文地址:https://www.cnblogs.com/remon535/p/12557082.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!