FILE TRANSFER POST-EXPLOITATION WITH "NON-INTERACTIVE" FTP
- Layout for this exercise:
data:image/s3,"s3://crabby-images/a88b1/a88b196b9064312cfa65a375ab73035874568e53" alt=""
1 - Introduction
- The goal of this exercise is to develop a method to transfer files from an attacking Kali Linux machine to a remote exploited Windows 7 machine using the command line.
- The problem with using FTP in "interactive" mode from a remote command line is that the transfer gets stuck even though the connection is successfully established.
- However, using FTP in "non-interactive" mode skips that problem and allows to transfer files to the exploited machine, what is essential in post-exploitation procedures.
2 - Setting up a FTP server at Kali Linux
- First of all, let's install and establish an FTP server at Kali Linux machine where the target Windows 7 will connect to download interesting files for post-exploitation purposes.
- Pure-FTPd is a free BSD license FTP server with a strong focus on security:
https://www.pureftpd.org/project/pure-ftpd
https://en.wikipedia.org/wiki/Pure-FTPd
- Installing the Pure-FTPd on Kali Linux:
data:image/s3,"s3://crabby-images/9b8ad/9b8ad47bddd9526b625aa7f1926670d44fe02fbb" alt=""
- Writing a bash script to configure the FTP server in order to create a user whitelist and its corresponding groups, also a folder /ftphome, and finally restarting the service:
data:image/s3,"s3://crabby-images/34605/346051a3987bf609272e7c2753b78e4bc20a018b" alt=""
data:image/s3,"s3://crabby-images/a491f/a491f0d03f8bcf15e22a317aadf9d227ef0db834" alt=""
- Giving permissions to the bash script:
data:image/s3,"s3://crabby-images/bf96d/bf96d2a701fbae340474af241cdd2e0648d191a3" alt=""
- Running the script:
data:image/s3,"s3://crabby-images/c3af7/c3af7af4532cf7552fe4722cae6a13c591ecc1b5" alt=""
- Now, let's check that the Pure-FTPd service is locally running at TCP port 21:
data:image/s3,"s3://crabby-images/1fcac/1fcac0e116f8c3cfb823a33d5b4c28930242c47a" alt=""
- Copying a windows binary file sbd.exe to /ftphome that will be later transferred to the target machine Windows 7:
data:image/s3,"s3://crabby-images/0a333/0a333891be658d7a77846872e17a23198fd695ea" alt=""
data:image/s3,"s3://crabby-images/2f391/2f3918010bb515e42609570f5c7571c7b5722708" alt=""
3 - Exploiting the target Windows 7
- The target to be exploited runs the vulnerable BadBlue HTTP server at port TCP 80:
data:image/s3,"s3://crabby-images/9ea38/9ea3878052bab92cdbdc050ebd2208de7afbf928" alt=""
- Starting Metasploit:
data:image/s3,"s3://crabby-images/e8876/e887670f9950df59dab689d852e5f336ade7c0a9" alt=""
- Using a BadBlue exploit:
data:image/s3,"s3://crabby-images/46f1a/46f1a6d6fad045331303592fed4a374611761771" alt=""
- Setting the target IP:
data:image/s3,"s3://crabby-images/6ec1d/6ec1df8d711718998f5de0d23f296829c0900039" alt=""
- Running the exploit, finally a remote shell from Windows 7 is achieved locally at Kali Linux:
data:image/s3,"s3://crabby-images/2c445/2c44554d9d31782836970e3e90a53975cba753ab" alt=""
4- Post exploitation with "non-interactive" FTP
- Let's check that the "interactive" FTP mode does not work for transferring files.
- After connecting to the FTP server and entering username and password the process gets stuck, not being possible to perform any transferring task:
data:image/s3,"s3://crabby-images/9ef4c/9ef4c3a718cf9aefd3300961535ff01bc00fe799" alt=""
- So we can conclude that the normal way of using interactive FTP commands is not useful for transferring files when using a remote command line, usually achieved after exploitation of the target machine.
- However, there is a non interactive FTP way of perform file transfers, using the -s filename option for the ftp command:
data:image/s3,"s3://crabby-images/81c6e/81c6e86d9d12839f81e105fd570c8a9908b52788" alt=""
- The ftp -s:filename option refers to a text file containing all the necessary commands to perform an FTP transfer file.
- Before checking how it works, let's create an specific directory /FTPtransfer where to transfer files from Kali Linux to the Windows 7 machine:
data:image/s3,"s3://crabby-images/afc15/afc155258dbda731944b9284442f8507ba22446d" alt=""
- Let's check that at this point /FTPtransfer is empty:
data:image/s3,"s3://crabby-images/f866d/f866dfa803270ffdda65d4c7929b01360c4930f9" alt=""
- As said before, the file to be transferred is the sbd.exe located at /ftphome:
data:image/s3,"s3://crabby-images/2371e/2371e8e9c627dd06efd76d82a56defb05fc81d45" alt=""
- Now, using the echo command, let's create a text file ftp_commands.txt where to write all the FTP commands that will perform the transfer:
data:image/s3,"s3://crabby-images/0c403/0c4035a2e153b6ed32cd8ba39986676f56d4ed5c" alt=""
- Checking the contents of ftp_commands.txt:
data:image/s3,"s3://crabby-images/510d8/510d882bac0ee6ce6621dc0aa538da69e067a79a" alt=""
- Now it's time to run the ftp command in "non-interactive" mode, just adding the -s:ftp_commands.txt option:
data:image/s3,"s3://crabby-images/dec2e/dec2e1ab152b0f1301b87ab87a79211ff72403c2" alt=""
- Eventually the transfer is successful:
data:image/s3,"s3://crabby-images/67f73/67f733b78c1e2ec3dd9af7cf7a95809eacc0e6f2" alt=""