Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alexzielenski/optool
Command Line Tool for interacting with MachO binaries on OSX/iOS
https://github.com/alexzielenski/optool
Last synced: 2 days ago
JSON representation
Command Line Tool for interacting with MachO binaries on OSX/iOS
- Host: GitHub
- URL: https://github.com/alexzielenski/optool
- Owner: alexzielenski
- License: bsd-2-clause
- Created: 2014-08-05T05:24:18.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2019-09-06T06:35:12.000Z (over 5 years ago)
- Last Synced: 2025-01-06T04:05:08.588Z (9 days ago)
- Language: Objective-C
- Homepage:
- Size: 94.7 KB
- Stars: 1,190
- Watchers: 52
- Forks: 234
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome - optool - Command Line Tool for interacting with MachO binaries on OSX/iOS. (OOM-Leaks-Crash / 逆向开发)
README
optool
======optool is a tool which interfaces with MachO binaries in order to insert/remove load commands, strip code signatures, resign, and remove aslr. Below is its help.
```
optool v0.1USAGE:
install -c -p -t [-o=] [-b] [--resign] In
serts an LC_LOAD command into the target binary which points to the payload. T
his may render some executables unusable.uninstall -p -t [-o=] [-b] [--resign] Removes any L
C_LOAD commands which point to a given payload from the target binary. This ma
y render some executables unusable.strip [-w] -t Removes a code signature load command from the given bi
nary.restore -t Restores any backup made on the target by this tool.
aslr -t [-o=] [-b] [--resign] Removes an ASLR flag from the m
acho header if it exists. This may render some executables unusableOPTIONS:
[-w --weak] Used with the STRIP command to weakly remove the signature. Withou
t this, the code signature is replaced with null bytes on the binary and its L
OAD command is removed.[--resign] Try to repair the code signature after any operations are done. Thi
s may render some executables unusable.-t|--target Required of all commands to specify the target executable
to modify-p|--payload Required of the INSTALL and UNINSTALL commands to speci
fy the path to a DYLIB to point the LOAD command to[-c --command] Specify which type of load command to use in INSTALL. Can be re
export for LC_REEXPORT_DYLIB, weak for LC_LOAD_WEAK_DYLIB, upward for LC_LOAD_
UPWARD_DYLIB, or load for LC_LOAD_DYLIB[-b --backup] Backup the executable to a suffixed path (in the form of _backup
.BUNDLEVERSION)[-h --help] Show this message
(C) 2014 Alexander S. Zielenski. Licensed under BSD
```License
===optool is licensed under BSD. Below is the license reproduced in its entirety:
```
Copyright (c) 2014, Alex Zielenski
All rights reserved.Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:* Redistributions of source code must retain the above copyright notice, this
list of conditions and the following disclaimer.* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
```