论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
ToB企服应用市场:ToB评测及商务社交产业平台
»
论坛
›
安全
›
网络安全
›
堆块的重叠
堆块的重叠
反转基因福娃
金牌会员
|
2024-5-17 21:44:20
|
显示全部楼层
|
阅读模式
楼主
主题
917
|
帖子
917
|
积分
2751
堆块重叠
对堆的了解不是很多,大部分都是本身网上找的资料了解的,以后每一道堆题我都会仔仔细细的写出来。这里先拿一道做示范
题目链接:
https://pan.baidu.com/s/1HbHkdHbEzt4UIe44gW8uqg
提取码:Ch13
看保护,pie保护关闭,延迟绑定,got表可以修改
64位ida载入
我们看看实现的功能
实际上这个就是指针用来找到我们堆的位置
思路是:1.我们先申请一个大小为0x18大小的堆,和一个大小0x10的堆
2.然后编辑第1个堆输入/bin/sh\x00而且使size位为0x41使指针位置变化
3.然后free第二个堆申请一个大小为0x30大小的堆(实际上加上头部是0x41,刚刚好申请到刚才free的堆)
4.通过覆盖到指针的位置为got表来泄露libc地址
5.通过编辑堆修改free@got为system地址
6.通过free第给堆拿到shell
先贴一下wp我再详细解释
为什么申请0x18大小后不是(0x18+0x11)大小而是0x21
因为我们申请0x18时间,下一个chunk的prev_size也是可以被我们利用的加上刚刚好
\0x41怎么样来的,这个紧张是我们溢出修改第二个chunk(第二个chunk指针)的size段,实际上就是修改指针
修改之前
修改后
那么我们就控制了指针然后就可以泄露libc地址和修改got表了,然后拿到shell
以上都是我本人的明白如果有任何不对的,烦请各位师傅实时指出
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
回复
使用道具
举报
0 个回复
正序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
发新帖
回复
反转基因福娃
金牌会员
这个人很懒什么都没写!
楼主热帖
设计模式---组合模式
【Unity3D】Transform组件
拿到12家offer,想给大家分享一下面试 ...
Spark快速上手(4)Spark核心编程-Spark ...
【渗透攻击】PowerShell与Shell 有什么 ...
如何将鸿蒙(harmonyOS)系统退回安卓 ...
写了这么久Java项目,是否还记得你的第 ...
echarts使用及遇到的问题
使用 Kubeadm 部署 K8S安装
软件工程经济学第一章
标签云
存储
挺好的
服务器
快速回复
返回顶部
返回列表