Simple crackme Walkthrough
reference | kawaii-flesh's Simple crackme |
Scan with DIE
:
data:image/s3,"s3://crabby-images/ab374/ab374287055c423f1a63b397d930e0ba19de65bf" alt="die"
pdf @ main
:
data:image/s3,"s3://crabby-images/a49bf/a49bf48cbd15bdf651291ebbfe5c38806e07f0f2" alt="r2_pdf_main"
1 | lea rax, qword [var_1a0h] ; rax = address of variable var_1a0h |
I don’t know why r2
doesn’t disassemble this function.
So I use cutter
(still based on r2
..) and ghidra
.
Add several breakpoints, dc
to mov rdx, rax
to finish executing function 0x562911b75179:
data:image/s3,"s3://crabby-images/f81fd/f81fda0a7f04c6f18319be619809c7691594d806" alt="breakpoints"
Now the program will compare the memory of rax and rdx as shown above in the comments:
data:image/s3,"s3://crabby-images/4b565/4b56586a9a2debffc11f8aead0210e40d96c34cf" alt="memory"
proof
data:image/s3,"s3://crabby-images/e2679/e267947c1db185f0f3d9593a9d35920ae785c42f" alt="proof"
Crack the hash online:
data:image/s3,"s3://crabby-images/508a3/508a3c981ead6994f478922c3bbc183d71cf1bd3" alt="hash"
- disassemble with
cutter
:
data:image/s3,"s3://crabby-images/2244a/2244a151fc0d920c4cddbf9dcb26c5235c196182" alt="cutter"
- decompile with
ghidra
:
data:image/s3,"s3://crabby-images/bc139/bc1390cb95a66aef2a77b8a198cd089ee2396500" alt="ghidra"