确认main_arena相对libc的偏移地址

前言

打保护全开的堆题时碰到的问题, 大佬wp直接给exp, 但是奈何萌新很多细节不懂啊
现在记录一下寻找main_arena相对libc偏移的方法(又水一篇博客)

在0CTF 2017 babyheap这题中, 利用 fast chunk 和 small chunk 堆叠技术将main_arena的实际地址泄露出来, 另外通过这个相对偏移, 计算libc的加载基址, 完成libc泄露

过程

对照看下mallo.c的源码
在这里插入图片描述

方法一

逆向分析libc.so文件
拖进IDA
函数框搜索malloc_trim
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

这里用libc-2.23.so版本的libc文件演示, 相对偏移就是0x3C4B20

方法二

gdb反汇编, 根据源码分析汇编指令可以得到相对偏移

[rsp + 0x14]是局部变量result
[rsp + 0x8]是局部变量ar_ptr, 所赋值就是&main_arena
在这里插入图片描述

总结

上来直接打高难度堆题, 到处碰壁, 很多问题只能一点点解决, 不过收获还是不小
很多exp把找地址这种《简 单 操 作》省略了, 纯萌新看得迷雾重重, 还是各种搜索和实践才找到解答, 以此记录一下, 另外malloc.c源码需要找个时间研读一遍, 顺便写个源码阅读笔记好了(flag就此立下)

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值