例行检查
分析程序,注意到在输入内容的时候,输入限制是这样的。
if ( (char *)(v3 + *(_DWORD *)*(&ptr + a1)) >= (char *)*(&ptr + a1) - 4 ){puts("my l33t defenses cannot be fooled, cya!");exit(1);}
意思是上一块的chunk的数据开始加上输入字符串的长度,不能超过下一个chunk的size字段。这个check在两个chunk相邻时是有效的,但是如果两个chunk不相邻时就会有问题,会造成堆溢出。
步骤
1.创建两个note(4个chunk)
2.free掉第一个note,2个chunk会合并。
3.创建大小为第一个note两个chunk之和,这样这个note两个chunk就会被第二个note隔开,于是可以溢出到第二个note。
4.gothijack
from pwn import *i
本文发布于:2024-01-28 22:41:38,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170645290510817.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |