Today we will walkthrough a simple room that covers the basics of command injection.
data:image/s3,"s3://crabby-images/5e8c7/5e8c7855b286b6917546802b7d08d32c38440511" alt=""
The target site is a web application that converts Linux timestamps to a more human friendly format.
data:image/s3,"s3://crabby-images/4c73c/4c73c337030588ac410fc0ddb03fe1a9a7049b9b" alt=""
In the description of this room they talk about how this app functions essentially the same as a cli utility so let’s try injecting some commands into this room.
data:image/s3,"s3://crabby-images/a420e/a420e8235d26a667dec463dc6b6e1ed3c35e79a9" alt=""
One way to execute a second command is to use double ampersands. Our input is being put directly into the syntax of the command so the “&&” allows us to run another command after the conversion and then both results are printed on the site. Let’s exploit this to get a shell on the machine.
data:image/s3,"s3://crabby-images/3aaf4/3aaf498c9e3111c22c9a04d10e5aab04d45a8f51" alt=""
We’ll inject this one liner into the website to launch a shell then catch it with a nectat listener. Put this command after the && in the site.
data:image/s3,"s3://crabby-images/3a27a/3a27a47cd8efd17eba34ac2a2b6eb0d30de36e92" alt=""
This is what your nectat should look like.
data:image/s3,"s3://crabby-images/fcf29/fcf2922d33a2df29abc9e6d986d28b45c12f8cc8" alt=""
Once I got access to the machine I began enumerating it and found the flag stored in the environment variables. To view the environment variables use the command “printenv”.