ENCRYPTED FILE TRANSFER WITH SFTP (SSH/SECURE FILE TRANSPORT PROTOCOL)
- Layout for this exercise:
data:image/s3,"s3://crabby-images/a0033/a0033b49f3ffc1a5abc74fdabaab75b2ebd75644" alt=""
1 - Introduction to SFTP
- SFTP (SSH or Secure File Transport Protocol) is a network protocol that provides encrypted file access, file transfer, and file management over any reliable data stream.
- SFTP was designed by the IETF (Internet Engineering Task Force) as a subsystem of SSH, sharing the same port 22 by default.
- SFTP assumes that it is run over a secure channel, such as SSH, that the server has already authenticated the client, and that the identity of the client user is available to the protocol.
https://en.wikipedia.org/wiki/SSH_File_Transfer_Protocol
- Linux manual for SFTP:
data:image/s3,"s3://crabby-images/ae121/ae121071655467d2aec789554e6946ae1c282555" alt=""
data:image/s3,"s3://crabby-images/6a1c7/6a1c7e12ec24e00774a3cfc2a4b9d9fcfb3e2dbb" alt=""
2 - Installing and starting SFTP
- Because SFTP is dependent on the very common service SSH it is usually installed by default. However, just in case it is not installed and activated, follow the next instructions.
- Installing and starting the service SSH at Debian:
data:image/s3,"s3://crabby-images/2606e/2606ed5e6a41bd2ea095bffb99bf0eba1f8ed27c" alt=""
data:image/s3,"s3://crabby-images/85f70/85f70cdde75e343ff96cf25a596f9c6e87297130" alt=""
data:image/s3,"s3://crabby-images/0c0aa/0c0aad6510e2c2674aadf5c558c6dae759e1aee8" alt=""
- Installing and starting the service SSH at Kali:
data:image/s3,"s3://crabby-images/b8a9b/b8a9bd6cf662a3500c3457af91f7c02f729008c6" alt=""
data:image/s3,"s3://crabby-images/e2698/e2698c5014608de2e33a0ea39f41d820665ceb5f" alt=""
data:image/s3,"s3://crabby-images/527cc/527cc36c26ed731b1d5cb593acdd6a4c83c4f57d" alt=""
3 - Connecting with SFTP
- From Kali let's start an SFTP connection to Debian using user marie:
data:image/s3,"s3://crabby-images/ec7df/ec7df91302044bfe5baa1cf234f6988a0b35cad6" alt=""
- Determining the remote current directory with pwd:
data:image/s3,"s3://crabby-images/28cd1/28cd1143dc67a58b2bc9504c58fe5eec4eac34d5" alt=""
- To have help about SFTP commands just use the command ?:
data:image/s3,"s3://crabby-images/5eb2a/5eb2af9faa2ceca8d61dd6bc707b62aaed3d8b75" alt=""
4 - GET command to download files with SFTP
- Debian has got a local file that Kali is interested to download:
data:image/s3,"s3://crabby-images/3786c/3786c50c29ed655d80b54bcb82f0c675fa27b6dc" alt=""
- Searching for the file remotely from Kali:
data:image/s3,"s3://crabby-images/99259/992594936dc4cc0eb5706766f2ad0c687d53f9d1" alt=""
- Changing to the directory that holds the file:
data:image/s3,"s3://crabby-images/d39e6/d39e692f0f6aa3a161dae029290fdb2288242791" alt=""
- Listing the file:
data:image/s3,"s3://crabby-images/3b834/3b83433957d3c1f5f58623073b9e456185e192e9" alt=""
- The command get followed by the filename downloads it from Debian to Kali:
data:image/s3,"s3://crabby-images/c06c3/c06c357209429ef0291c2e19634cf10695f3b5d0" alt=""
- Checking that the downloading process has been successful:
data:image/s3,"s3://crabby-images/e7fc8/e7fc818b671325e5e5c662b46154f028b32de9b7" alt=""
data:image/s3,"s3://crabby-images/c42b5/c42b5ccf98e9af33ded9c7126674ab2c49b376eb" alt=""
5 - PUT command to upload files with SFTP
- Creating a new directory remotely at Debian from Kali:
data:image/s3,"s3://crabby-images/9c456/9c4563bc32c951fdb57d64075355bf2bcee1f405" alt=""
- Changing to the new directory:
data:image/s3,"s3://crabby-images/284d5/284d5b4b8d3d993cd9df1894e1820abde3c4a24c" alt=""
- Kali has got a local file that is going to be uploaded to Debian:
data:image/s3,"s3://crabby-images/3f0d3/3f0d3b998c9dd0068ed89fa1e493f8ba3ab9a667" alt=""
- The command put followed by the path to the local file and its filename triggers the uploading process:
data:image/s3,"s3://crabby-images/fa822/fa822eb96b5b80a4c5ee9910d647a2746df268f0" alt=""
- Checking that the uploading process has been successful:
data:image/s3,"s3://crabby-images/87882/8788293389d9e3edd625ae4235995baa8ea1fd39" alt=""
data:image/s3,"s3://crabby-images/7d258/7d2584ffec7f8b9815fbb17bbb09d61581994cc2" alt=""
data:image/s3,"s3://crabby-images/2a7fa/2a7fa84feaf14a2e18e9e90890340709c09f3c55" alt=""
6 - RM command to remove files remotely with SFTP
- Now, let's remove the uploaded file with rm command:
data:image/s3,"s3://crabby-images/9811a/9811ae97ed01d363f4a4019119b0cd5958690a7a" alt=""
- Checking that the removal has been successful:
data:image/s3,"s3://crabby-images/8dde4/8dde4556476ab7928e80da539de14207fcc87e72" alt=""
7 - Analyzing the encrypted SFTP connection with Wireshark
- Starting Wireshark at the Kali machine:
data:image/s3,"s3://crabby-images/3453f/3453fca6c663292700158180f55c13bd25e3e5ab" alt=""
- Applying filter: ssh (because SFTP is a subsystem of SSH) the whole connection between Debian (192.168.1.18) and Kali (192.168.1.19) is available. Let's notice that the destination port at Debian is port 22, as expected:
data:image/s3,"s3://crabby-images/b6c3e/b6c3e2d5b9ebeabfa707e0805e1e7e8fc68cf6a8" alt=""
- It is interesting to check that the whole connection is encrypted, so a potential sniffer could not access to the real contents of the transfer. For instance:
data:image/s3,"s3://crabby-images/ee7e0/ee7e074f9aadb90796c34c4c8698cd45ccb5f1e7" alt=""
data:image/s3,"s3://crabby-images/a0adb/a0adbae33f74a839adbf59e31dca5bcd4179818b" alt=""
- Also, applying Follow TCP Stream option, the stream is displayed encrypted:
data:image/s3,"s3://crabby-images/30198/30198d3192e6318f709a2d052dea3cc4bcbb604d" alt=""