easy keyg3nme Walkthrough
reference | ezman's easy keyg3nme |
Use horsicq/Detect-It-Easy to identify the binary first:
data:image/s3,"s3://crabby-images/05978/05978a38617e89da2dd8645ea3f329aff1538a75" alt="die"
Here I use two methods:
radare2
pdf @ main
to print disassemble function main
:
data:image/s3,"s3://crabby-images/7a8cb/7a8cbf9e71898a3a87e6473e44328961ce4ee31e" alt="r2_main"
Address 0x55ee5b4f11b4 and 0x55ee5b4f11b4 need register eax to be 1 to go to address 0x55ee5b4f11b9.
pdf @ sym.validate_key
:
data:image/s3,"s3://crabby-images/62794/62794c50855719d4ec7891a5e69419c71f5540ae" alt="r2_validate_key"
Function validate_key
:
1 | mov ecx, dword [var_4h] ; ecx = arg1 |
I’ve not figured out what does it mean by edx_new * (2**32) + eax_new = arg1 * 449514157
.
Try to set register edx to 1 after executing sar edx, 7
, which leads register ecx to 0x4c7.
Verify imul edx
:
data:image/s3,"s3://crabby-images/ea28a/ea28a28ef95aa7f297857d50686e05bc97f13788" alt="cal_imul"
0x80 is just 128.
Also set register edx to 2, which leads register ecx to 0x98e.
data:image/s3,"s3://crabby-images/77fc7/77fc74ad06ca02e43fc8a281d48891d662d55bd4" alt="cal_imul2"
data:image/s3,"s3://crabby-images/02797/02797e93ee891ea75b1a9b0035b6fa243b12d13b" alt="cal_sar"
ghidra
Use ghidra
is quite easy, thanks to the build-in decompiler.
Load the binary to ghidra
, and navigate to Symbol Tree
to enumerate existed functions:
data:image/s3,"s3://crabby-images/1608d/1608df55ff5c5199ef9480bd50281326eec944a5" alt="ghidra_functions"
Navigate to function validate_key
:
data:image/s3,"s3://crabby-images/d0d28/d0d28c35f7e07dd09cf3b0367e3c6cf05e531fab" alt="ghidra_validate_key"
Navigate to function main
:
data:image/s3,"s3://crabby-images/6ab65/6ab65e47f9c9ff54c89dd0e482dc26f95fae5201" alt="ghidra_main"
Function main
:
- read variable
local_14
from stdin - pass variable
local_14
to functionvalidate_key
, get result in variableiVal1
- check variable
iVal1
proof
data:image/s3,"s3://crabby-images/00890/00890e4cebbbba93b88ce127058d2744269a16be" alt="pwn_2"