Level 8 of the OverTheWires Natas wargame was pretty simple, as a developer, but could prove more difficult if you don’t have similar background.
It starts out with a secret password input.
data:image/s3,"s3://crabby-images/bec09/bec09de7c173b0368f3d9712248c8c0df55139ad" alt=""
Like other levels, I looked at the source code to see what was going on in the background.
data:image/s3,"s3://crabby-images/502c8/502c88296aae41f7e8ccd91287a588d49b4a196b" alt=""
Based on this code, you can see that it has a stored secret value, that is base64 encoded, then reversed, and then converted to a hex string. That value is then compared to the stored secret value, and if it’s a match, it will give you the next level’s password.
I decided to write a reversal program in php, since it was super easy. The only problem it gave me, was that there is no built-in hex2bin method until a newer version of PHP than I had on my machine. Luckily, on the bin2hex documentation page, someone kindly wrote a reversal function that I stole.
data:image/s3,"s3://crabby-images/d863b/d863b5aa343f26f10a7448ae388be22b317044c4" alt=""
Once I executed that program in php, it gave me the decoded password. Once I entered it into the page, it gave me the password to the next level.
data:image/s3,"s3://crabby-images/1ab86/1ab86bf925447bd3f7c10e1e8a61fa8afef9cc1f" alt=""