data:image/s3,"s3://crabby-images/756b6/756b6548fda3aed016592ea434c8445e150ba57b" alt=""
Level16
After accessing level16 account, check the hint as follows.
data:image/s3,"s3://crabby-images/038e1/038e11c09dde03b3ec9b96e50f96293fac6535d9" alt=""
When viewed in the code. If I call up the shell() function using call function in the main, I can execute the level17 shell. After copying to the tmp folder, I execute the program added a line of code to find out the memory structure.
data:image/s3,"s3://crabby-images/a0a22/a0a223bd9dbada1db0de1223ea87284993f6ece5" alt=""
And then, I analyze the attackme using gdb.
data:image/s3,"s3://crabby-images/4cef8/4cef80e99adbf022331c9da4a051654e284615bd" alt=""
Based on above two analysis, The structure of stack is shown as follows.
data:image/s3,"s3://crabby-images/94057/94057258f2a3fa3ede396e3a8f860150113fd8f7" alt=""
I need the address of shell() function. Because I execute the shell() function through the call() function. So, I find address of the shell() function using gdb.
data:image/s3,"s3://crabby-images/430ce/430ced15cf57e9c263c920836dd9a183843fa3c3" alt=""
When I disassemble the shell, I find the starting address of shell function. When I type dummy values as 40byte and the address of shell() function, the call function execute the shell() function.
data:image/s3,"s3://crabby-images/fb4e6/fb4e66419690f4583c55289aba3fd7d99f921634" alt=""
As a result, the level17 shell is executed. I confirm the password of level17 is “king poetic”.
No comments:
Post a Comment