easy_one Walkthrough
reference | scifi's easy_one |
Identify the binary with DIE
:
data:image/s3,"s3://crabby-images/9c298/9c298894060a8bfeeec57912c4abcd168639b08b" alt="die"
Since I don’t have a MAC machine, I can only use ghidra
to do some static analysis.
Load the binary with ghidra
, and navigate to decompile:
data:image/s3,"s3://crabby-images/003f6/003f6080b683a1d8953f1ff4002e1c19026dbe7b" alt="ghidra_decompile"
According to man strcspn
:
The strcspn() function calculates the length of the initial segment of s which consists entirely of bytes not in reject.
1 | undefined8 entry(void) |
data:image/s3,"s3://crabby-images/3a2e6/3a2e61c9906b7bd3c905ad00e1396bb1adf4ee0f" alt="ghidra_list"
1 | MOVSX EAX, byte ptr [RBP + local_118] ; first element of the array |
So, the input must be:
- 10 chars without ‘\n’
- first char equals to the last char
proof
Run Mach-O binary on Linux with shinh/maloader:
data:image/s3,"s3://crabby-images/0fdc2/0fdc28843fd8288b6b8fd6ec4e3e07bf58e1cb8a" alt="proof"