从入门到遗忘:double free —— 2015 0CTF freenote

emmmm之前一直在入门windows,好久都没怎么碰linux了,逛大神博客碰到了这道题的wp,拿来复习下。

好像是2015 0CTF的freenote这道题。

先拿来扔进IDA,改好函数名,大致了解程序流程和note结构体。大致是一开始先申请了一个大只堆块用来作为目录,然后每个note占24字节:

+0        inuse

+8        note length

+16      point to note buffer

其中会note的长度经过对齐后作为malloc的参数,用脚本模拟了对齐的逻辑,0对齐还是0,0~0x80对齐为0x80。

漏洞点主要在free的时候没有清掉目录中的项尤其是堆地址。

这样如果申请三个堆块,然后释放掉,这三个堆块将合并为一个大堆块。倘若再申请一个大堆块(大小为三个小堆块之和),大堆块将从原本0号堆块的位置开始,且可以通过目录中的堆地址进行访问,从而可以伪造堆块并进行dword shoot。

0x00 泄露堆地址 & libc

en其实libc基址也可以后面搞,这里有点忘就直接用uaf泄露main_arena然后换算得到libc基址。

堆地址也差不多,创建4个堆然后释放0、2号(其实好像3个也可以,遗忘太可怕),这时候0号堆块fd和bk将指向2号堆块构成双向链表,再用uaf把0号拿回来:

0号堆块被从链表中拆掉后,2号堆块的fd和bk都会指向main_arena+88的位置,再uaf,然后拿到一个堆地址和main_arena+88的地址,相应换算后得到指向0号chunk_list的地址和libc基址。

0x01 伪造chunk & 覆写GOT表

伪造chunk,都是套路,相应的presize和size要写对。

free了2号堆块没问题之后基本就ok了,可以gdb attach一下看目录中原本0号堆块的位置变成了chunk list的地址,接下来对0号note进行edit,用户输入将写入该地址,从而覆盖0号note的指针,继而可以实现任意地址写。

还有一个要注意的也是卡了很久的地方,double free之后目录中chunk0的指针已经被覆盖了,这时如果remalloc的话会出错终止,所以edit的时候必须在后面填充paddings使得长度与create的时候一样,才不会去调用remalloc。

以及第一次edit覆盖的起始位置还要在chunk0指针往前一点,会覆盖掉inuse位和length,要确保inuse仍然是1,然后length可以在第一次edit的时候改小一点,比如emmm,8,接着覆盖掉chunk0指针为atoi的got表地址,然后第二次edit,即向atoi的got表项写入system的实际地址。

回到main函数,我的choice?,输入/bin/sh就好,然后atoi(buff)实际上就是system('/bin/sh')。

遗忘真的是个可怕的朋友。emmm故作帅气的这么说着。

========================================================================

《大明妖孽》很好看,机械键盘深似海。

多陪陪家人很重要。不要总是自作聪明的 “我以为是这样的”。

新年快乐。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341

推荐阅读更多精彩内容