ROPgadget - This Tool Lets You Search Your Gadgets On Your Binaries To Facilitate Your ROP Exploitation


This tool lets you search your gadgets on your binaries to facilitate your ROP exploitation. ROPgadget supports ELF/PE/Mach-O format on x86, x64, ARM, ARM64, PowerPC, SPARC and MIPS architectures. Since the version 5, ROPgadget has a new core which is written in Python using Capstone disassembly framework for the gadgets search engine - The older version can be found in the Archives directory but it will not be maintained.

Install
If you want to use ROPgadget, you have to install Capstonefirst.
For the Capstone's installation on nix machine:
$ sudo pip install capstone
Capstone supports multi-platforms (windows, ios, android, cygwin...). For the cross-compilation, please refer to the https://github.com/aquynh/capstone/blob/master/COMPILE.TXT file.
After Capstone is installed, ROPgadget can be used as a standalone tool:
$ ROPgadget.py
Or installed into the Python site-packages library, and executed from $PATH.
$ python setup.py install
 $ ROPgadget
Or installed from PyPi
$ pip install ropgadget
 $ ROPgadget

Usage
usage: ROPgadget.py [-h] [-v] [-c] [--binary ] [--opcode ]
                     [--string ] [--memstr ] [--depth ]
                     [--only ] [--filter ] [--range ]
                     [--badbytes ] [--rawArch ] [--rawMode ]
                     [--re ] [--offset ] [--ropchain] [--thumb]
                     [--console] [--norop] [--nojop] [--nosys] [--multibr]
                     [--all] [--dump]
 
 optional arguments:
     -h, --help           show this help message and exit
     -v, --version        Display the ROPgadget's version
     -c, --checkUpdate    Checks if a new version is available
     --binary     Specify a binary filename to analyze
     --opcode    Search opcode in executable segment
     --string     Search string in readable segment
     --memstr     Search each byte in all readable segment
     --depth       Depth for search engine (default 10)
     --only          Only show specific instructions
     --filter        Suppress specific instructions
     --range   Search between two addresses (0x...-0x...)
     --badbytes     Rejects specific bytes in the gadget's address
     --rawArch      Specify an arch for a raw file
     --rawMode      Specify a mode for a raw file
     --re             Regular expression
     --offset    Specify an offset for gadget addresses
     --ropchain           Enable the ROP chain generation
     --thumb              Use the thumb mode for the search engine (ARM only)
     --console            Use an interactive console for search engine
     --norop              Disable ROP search engine
     --nojop              Disable JOP search engine
     --callPreceded       Only show gadgets which are call-preceded (x86 only)
     --nosys              Disable SYS search engine
     --multibr            Enable multiple branch gadgets
     --all                Disables the removal of duplicate gadgets
     --dump               Outputs the gadget bytes

Screenshots





https://github.com/JonathanSalwan/ROPgadget

تعليقات

المشاركات الشائعة من هذه المدونة