成都黑客网:非栈上格式化字符串缝隙使用技巧

访客4年前黑客工具463

成都黑客网:非栈上格式化字符串缝隙使用技巧

关于Linux栈上格式化字符串缝隙的运用网上已经有许多讲解了,但对错栈上的格式化字符串缝隙很少有人介绍。这儿首要以上周末SUCTF竞赛中playfmt标题为例,具体介绍一下bss段上或堆上的格式化字符串运用技巧。
 
0x01基础知识点
格式化字符串缝隙的具体原理就不再具体叙说,这儿首要简略介绍一下格式化参数方位的核算和缝隙运用时常用的格式字符。
参数方位核算
linux下32位程序是栈传参,从左到右参数次序为$esp+4,$esp+8,...;因此$esp+x的方位应该是格式化第x/4个参数。
linux下64位程序是寄存器加栈传参,从左到右参数次序为$rdi,$rsi,$rdx,$rcx,$r8,$r9,$rsp+8,...;因此$rsp+x的方位应该是格式化第x/8+6个参数。
常用的格式化字符
用于地址走漏的格式化字符有:%x、%s、%p等;
用于地址写的格式化字符:%hhn(写入一字节),%hn(写入两字节),%n(32位写四字节,64位写8字节);
%$type:直接效果第number个方位的参数,如:%7$x读第7个方位参数值,%7$n对第7个参数方位进行写。
%c:输出number个字符,合作%n进行恣意地址写,例如"%{}c%{}$hhn".format(address,offset)便是向offset0参数指向的地址更低位写成address。
 
0x02非栈上格式化字符串缝隙运用
​ 一般来说,栈上的格式化字符串缝隙运用过程是先走漏地址,包含ELF程序地址和libc地址;然后将需求改写的GOT表地址直接传到栈上,一同运用%c%n的 *** 改写入system或one_gadget地址,最终便是绑架流程。可是关于BSS段或是堆上格式化字符串,无法直接将想要改写的地址指针放置在栈上,也就没 *** 完成恣意地址写。下面以SUCTF中playfmt为例,介绍一下常用的非栈上格式化字符串缝隙的运用 *** 。
例题
标题阐明
程序缝隙点比较显着,直接写了一个循环的printf格式化缝隙,而输入的数据是存储在buf指针上,buf则是坐落bss段中地址为0x0804B040。
int do_fmt(void)
{
  int result; // eax
  while ( 1 )
  {
    read(0, buf, 0xC8u);
    result = strncmp(buf, "quit", 4u);
    if ( !result )
      break;
    printf(buf);
  }
  return result;
}
.bss:0804B040                 public buf
.bss:0804B040 ; char buf[200]
.bss:0804B040 buf             db 0C8h dup(?)    ; DATA XREF: do_fmt(void)+E↑o
查看一下程序的维护,可以发现敞开了RELRO,也便是无法改写GOT表,所以思路便是直接修正栈上的回来地址,return的时分绑架流程。

走漏地址
首要需求得到当时栈的地址和libc的基地址,这些地址可以很轻松的在栈上找到,其间esp+0x18寄存了栈地址,esp+0x20寄存了libc的地址,可以得到分别是第6个参数和第8个参数,直接传入%6$p%8$p即可得到栈地址和libc地址。

恣意地址写
这儿首要需求处理的便是怎么即将改写的地址放在栈上。完成恣意地址写需求依靠栈上存在一个链式结构,如0xffb5c308->0xffb5c328->0xffb5c358,这三个地址都在栈

相关文章

淘宝有黑客接单暗号(先做事后收款黑客接单)?

先做事后收款的黑客接单,现在的淘宝简直就是万能宝,面对各式各样的物品或者办事情好多的人都会在淘宝上面搜索,那么如果想在淘宝上面联系黑客的话,一般接头的暗语是什么,我们要怎么才能联系到先做事后收款的那些...

微信公众功能介绍范文?微信公号功能介绍怎么写

微信公众功能介绍范文?微信公号功能介绍怎么写

这是一篇讲述功能介绍的文章,但是为什么小编把它归类到微信定位的栏目内呢?这是因为功能介绍的明确程度,反映了这个微信公众号的定位是否明确,所以今天这篇文章说的,其实是如何精准的为公众号进行定位。...

被狗狗抓伤要不要打针(被狗狗抓伤应该怎么正

被狗狗抓伤要不要打针(被狗狗抓伤应该怎么正

饲在养狗狗的过程中,被狗抓伤在所难免,如果被狗狗抓伤了怎么办?应该怎么处理?需不需要打疫苗? 如果被狗狗抓伤皮肤表层,没有出血则先用盐水冲洗抓伤部位,然后再用棉棒蘸碘酒或酒精进行消毒,也可以用肥...

甜品加盟店需要多少钱?初次创业者需详细了解

甜品加盟店需要多少钱?初次创业者需详细了解

公共创业万众创新的时代趋势下,越来越多的有志人士选择了创业这条阶梯。但面临竞争如此剧烈的行业市场,想要实现利润最大化,加盟投资成为更多人的选择,强强连系才气实现共盈利的社会,餐饮行业成为更多淘金者的选...

黑客破解微信聊天软件

在我们日常使用这一款APP的时候,就会知道使用量是多么大的,而且它的使用占用面积也是非常强的。所以在我们日常生活当中,只要使用这一款APP就会形成很多的微信聊天数据,而且这些聊天数据占据的内存是很多的...

一百以内加减法(一百以内加减法练习题下载)

小学生100以内加减法练习题如下图:下面针对两道做下说明:41+19=这样的题目比较好算,个位数字+个位数字恰好是10,计。 加减法用算盘计算,比较直观。其基本规律是数位对齐,从高位算起。基本原理是十...