crackme1 Walkthrough
reference | crackmes.de's crackme1 by midi |
Scan with die
:
data:image/s3,"s3://crabby-images/71c4f/71c4fd65248585567754585997bbed4a9b04801f" alt="die"
Execute the binary:
data:image/s3,"s3://crabby-images/30409/3040909d77b8c32eb71ee6991d6cf600acfd4cf5" alt="crackme.exe"
Load the binary to ghidra
, and enumerate existed functions:
data:image/s3,"s3://crabby-images/f4b0d/f4b0d02b84caa65cefd106e3e5da0a6937b623dc" alt="ghidra_functions"
Show references to fopen
keyfile
:
data:image/s3,"s3://crabby-images/4da29/4da296781916ffc480264793e757eb2af5cfc91d" alt="ghidra_reference"
FUN_00401344
:
data:image/s3,"s3://crabby-images/b63a0/b63a059d8ec2e058c76c6fc9d81f1012bb7a99f7" alt="ghidra_decompile"
The program will:
fopen
lookhere.key
GetDriveTypeA
- check
_DAT_0040200c
The fastest method is patching the step 3:
data:image/s3,"s3://crabby-images/df197/df1977c244bca9b3e5bbb5066c3e3343e34d625f" alt="ghidra_patch"
Decompilation of the function:
data:image/s3,"s3://crabby-images/ca458/ca4580b6f3fcb46cfbd865963b60a7409fa30b6b" alt="ghidra_patch_2"
proof
Patch, save and export:
data:image/s3,"s3://crabby-images/06ef2/06ef2dd97d8537448cc7db66a8232f05a652ac7c" alt="proof"
data:image/s3,"s3://crabby-images/0df78/0df780eeececfe4cb9229b3a5ed78e4a52ade4bd" alt="r2_getdrivetypea"