data:image/s3,"s3://crabby-images/04ec6/04ec609d9b05fb296b4795c5e1ddbc4396442d6e" alt=""
Level12
After accessing with level12 account, check the hint as follows.
data:image/s3,"s3://crabby-images/3ff6c/3ff6cbb4ad9c61985cdc8d5af35b55bf57254989" alt=""
data:image/s3,"s3://crabby-images/3ff6c/3ff6cbb4ad9c61985cdc8d5af35b55bf57254989" alt=""
In the source code, first, The program declares a local variable str array of 256 bytes size. Then grant permission level13 (3093) to attackme. It outputs a string “ Input a sentence. ”, receives a string with the get functions, prints the input string, and exists.
data:image/s3,"s3://crabby-images/895e9/895e902bc9543cc7db73d74df1c25227e935fb8d" alt=""
I analyze it using gdb.When I think about the structure of the stack, it seems to be the same as level11.To use RTL ( Return To Libc ), I check whether ASLR was done using ldd command.
data:image/s3,"s3://crabby-images/44749/4474908111622f761b113741e811513a7aad6205" alt=""
As a result, I confirm that libc is not applied ASLR. All subsequent attack sequences are identical to level11. The address where /bin/sh is located and the address of the system function are also same. Level12 receives string input during program execution differently from level11, so I tried attack like the following, and as a result, I know the password of level13.
data:image/s3,"s3://crabby-images/e5d6b/e5d6b6a41acd434ddb470fe8346dbe0970dd959a" alt=""
No comments:
Post a Comment