How can I strip code signatures from macOS binaries?
ยท Around 1 minute
When compiling applications by default, they get invisibly signed in order to protect them from tampering.
This isn't always desirable such as if you want to use dtruss and other applications to monitor their system calls.
You can check if an application is signed like so:
$ codesign -dv ./main
Executable=/Users/marcus/Code/main
Identifier=a.out
Format=Mach-O thin (arm64)
CodeDirectory v=20400 size=15614 flags=0x20002(adhoc,linker-signed) hashes=485+0 location=embedded
Signature=adhoc
Info.plist=not bound
TeamIdentifier=not set
Sealed Resources=none
Internal requirements=none
$ codesign -dv ./main
Executable=/Users/marcus/Code/main
Identifier=a.out
Format=Mach-O thin (arm64)
CodeDirectory v=20400 size=15614 flags=0x20002(adhoc,linker-signed) hashes=485+0 location=embedded
Signature=adhoc
Info.plist=not bound
TeamIdentifier=not set
Sealed Resources=none
Internal requirements=none
You can remove the signature like so:
$ sudo codesign --remove-signature ./main
$ codesign -dv ./main
./main: code object is not signed at all
$ sudo codesign --remove-signature ./main
$ codesign -dv ./main
./main: code object is not signed at all
At the time of writing, I don't believe this is enough to actually let you run most things due to System Integrity Protection but it's worth a shot.