预备知识
关于ROP
ROP的全称为Return-oriented programming(返回导向编程),这是一种高级的内存攻击技术可以用来绕过现代操作系统的各种通用防御(比如内存不可执行和代码签名等)。
ROP是一种攻击技术,其中攻击者使用堆栈的控制来在现有程序代码中的子程序中的返回指令之前,立即间接地执行精心挑选的指令或机器指令组。
本系列rop实战题目的背景
来自ROPEmporium,旨在通过解决一系列挑战来一步步进阶学习ROP利用技术。
split涉及知识点
1)radare2使用(相关专栏:radare2实战)。
2)汇编程序(阅读、分析,要求熟悉相关指令、寄存器等)。
3)gdb使用。
4)ROPGadget使用。
5)pwntools使用(相关实验:基于pwntools编写pwn代码)。
实验目的
通过该实验学习ROP概念及其思路,了解高级栈溢出时需要注意的事项,并掌握解决方法,同时通过练习给出的关卡来增强实践能力。
实验环境
服务器:kali,IP地址:随机分配
题目文件与源码请在实验机内下载使用:http://tools.hetianlab.com/tools/ROP/2.zip
实验步骤一
这一关是split。
先使用file split命令看一下:

本文详细介绍了返回导向编程(ROP)的概念和在实际安全攻防中的应用。通过一个名为'split'的实战题目,讲解了如何利用radare2、gdb、ROPGadget和pwntools进行ROP利用技术的学习,包括分析汇编、查找gadget、构造exploit等步骤,最终实现通过溢出栈来执行特定指令并获取flag。
最低0.47元/天 解锁文章
731

被折叠的 条评论
为什么被折叠?



