In this guide, we will learn how to do basic operations on an sftp server.
The File Transfer Protocol is a standard communication protocol used for the transfer of computer files from a server to a client on a computer network.
FTP isn’t popular today because it Lacks Security. When a file is sent using this protocol, the data, username, and password are all shared in plain text, which means a hacker can access this information with little to no effort. For data to be secure, you need to use an upgraded version of FTP like SFTP.
SFTP Secure File Transfer Protocol is a file transfer protocol that provide secure access to a remote computer to deliver secure communications. It leverages SSH – Secure Socket Shell and is frequently also referred to as ‘Secure Shell File Transfer Protocol’.
# Related Content
- How to set up an SFTP server on Debian 11 Server
- Download Files from SFTP server Using a python script
- List, Upload and Download files from an SFTP Server using golang
- How to set up an SFTP server on OpenSUSE Leap 15.3 Server
- How to install and set up sftp server in Ubuntu 20.04
- How to set up an SFTP server on CentOS 8 /RHEL 8 Server
# Prerequisites
To follow along, ensure that you have the following:
- An SFTP server to connect to. If you want to set up the server check the guides above
- Credentials to connect to the server
# Table of content
- Connecting to SFTP server
- Checking sftp version
- Showing remote working directory
- Show local machine working directory
- Upload files to the sftp server
- Downloading files from the sftp server
- Creating and deleting directory in the sftp server
- Removing files in the sftp server
- Renaming files in the sftp server
- Checking file usage in the sftp server
- Getting help
# 1. Connecting to SFTP server
You can use the command line terminal to test your login to the SFTP. This can even be done locally in the sftp server.
This is the format of the login command:
sftp [user]@[host]
Lets connect to our server. your SFTP username and password will be needed.
sftp sftpuser1@192.168.10.10
Output:
$ sftp sftpuser1@192.168.10.10
The authenticity of host '192.168.10.10 (192.168.10.10)' can't be established.
ECDSA key fingerprint is SHA256:99KvuL95zO2CQbC8X0Re/Q+cYrJgqQgzpf1leemnjmY.
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added '192.168.10.10' (ECDSA) to the list of known hosts.
sftpuser1@192.168.10.10's password:
Connected to 192.168.10.10.
sftp>
This will log you in the server. The default directory is the /home
dir specified in the ChrootDirectory /home
directive in the ssh server configs.
# 2. Checking SFTP Version
Use the version command to check sftp version.
sftp> version
SFTP protocol version 3
sftp>
# 3. Show remote Working Directory
If you need to check the current working directory on the remote server, the pwd
command comes in handy:
sftp> pwd
Remote working directory: /sftpuser1
sftp>
# 4. Show Local machine Working directory
To show the local system’s present working directory use lpwd
command.
sftp> lpwd
Local working directory: /home/ubuntu
sftp>
The created user will only have access to its directory. Lets switch to that directory with the following command:
sftp> cd sftpuser1
sftp>
Move to the SFTP user home directory and try to create a new directory as following:
sftp> ls
sftpuser1 ubuntu
sftp> cd sftpuser1
sftp> ls
sftp> mkdir datadir
sftp> ls
datadir
# 5. Upload files to the sftp server
# Doing it from local
Upload files to a remote server using this command syntax:
$ sftp {user}@{host}:{remote-path} <<< $'put {local-path}'
Example:
$ sftp sftpuser1@127.0.0.1:/sftpuser1/ <<< $'put ./citizix.txt'
sftpuser1@127.0.0.1's password:
Connected to 127.0.0.1.
Changing to: /sftpuser1/
sftp> put ./citizix.txt
Uploading ./citizix.txt to /sftpuser1/citizix.txt
./citizix.txt
# Doing it from the sftp server
Use these commands: ls
to list files, lls
for local list, put
for uploading files:
sftp>
sftp> pwd
Remote working directory: /sftpuser1/datadir
sftp> ls
sftp> lls
citizix.txt snap tmp
sftp> put citizix.txt
Uploading citizix.txt to /sftpuser1/datadir/citizix.txt
citizix.txt 100% 32 25.8KB/s 00:00
sftp> ls
citizix.txt
sftp>
To upload multiple files in one go, we can use mput
command like in the example below. You can use mput
with regular expression like data[23]
to upload data2
, data3
and ignore data1
. You can use any wildcard or regular expression with mput
.
sftp>
sftp> pwd
Remote working directory: /sftpuser1/data
sftp> ls
sftp> lls
data1 data2 data3
sftp> mput data[23]
Uploading data2 to /sftpuser1/data/data2
data2 100% 0 0.0KB/s 00:00
Uploading data3 to /sftpuser1/data/data3
data3 100% 0 0.0KB/s 00:00
sftp> ls
data2 data3
# 6. Downloading files from the sftp server
# Doing it from the local machine
To download a file from a remote server, use the below command syntax:
$ sftp {user}@{remote-host}:{remote-file-name} {local-file-name}
Here’s a demo of downloading a file in one line using sftp:
# sftp sftpuser1@127.0.0.1:/sftpuser1/citizix.txt .
sftpuser1@127.0.0.1's password:
Connected to 127.0.0.1.
Fetching /sftpuser1/citizix.txt to ./citizix.txt
/sftpuser1/citizix.txt 100% 32 26.7KB/s 00:00
# Doing it from the remote sftp server
Download single file from the server using get
. Example downloading data2
sftp>
sftp> ls
data2 data3
sftp> lls
sftp> get data2
Fetching /sftpuser1/data/data2 to data2
sftp> lls
data2
sftp>
Use mget
to download multiple files like in this example
sftp>
sftp> ls
data2 data3
sftp> lls
sftp> mget data*
Fetching /sftpuser1/data/data2 to data2
Fetching /sftpuser1/data/data3 to data3
sftp> lls
data2 data3
sftp>
# 7. Creating and deleting directory in the sftp server
Use the commands mkdir
and rmdir
to create and delete directories
sftp>
sftp> ls
sftp> mkdir data
sftp> ls
data
sftp> rmdir data
sftp>
# 8. Removing files in the sftp server
Use the command rm
to delete files
sftp> rm data*
Removing /sftpuser1/data/data2
Removing /sftpuser1/data/data3
sftp>
# 9. Renaming files in the sftp server
Use the rename
command to rename files
sftp>
sftp> ls
data3
sftp> rename data3 data_original
sftp> ls
data_original
sftp>
# 10. Checking Filesystem Usage in the sftp server
Display statistics for the current directory or filesystem containing ‘path’, use df command. We can use -h flag to show statistics in a human-readable format. Do note that the statistics shown are for the remote SFTP server’s respective filesystem and not the local machine’s filesystem.
sftp> df
Size Used Avail (root) %Capacity
29540600 5917856 22103188 23622744 20%
sftp> df -h
Size Used Avail (root) %Capacity
28.2GB 5.6GB 21.1GB 22.5GB 20%
# 11. Getting Help
To get help about available commands and syntax for SFTP, use ‘?‘ or ‘help‘.
sftp> ?
Output:
sftp> ?
Available commands:
bye Quit sftp
cd path Change remote directory to 'path'
chgrp [-h] grp path Change group of file 'path' to 'grp'
chmod [-h] mode path Change permissions of file 'path' to 'mode'
chown [-h] own path Change owner of file 'path' to 'own'
df [-hi] [path] Display statistics for current directory or
filesystem containing 'path'
exit Quit sftp
get [-afpR] remote [local] Download file
help Display this help text
lcd path Change local directory to 'path'
lls [ls-options [path]] Display local directory listing
lmkdir path Create local directory
ln [-s] oldpath newpath Link remote file (-s for symlink)
lpwd Print local working directory
ls [-1afhlnrSt] [path] Display remote directory listing
lumask umask Set local umask to 'umask'
mkdir path Create remote directory
progress Toggle display of progress meter
put [-afpR] local [remote] Upload file
pwd Display remote working directory
quit Quit sftp
reget [-fpR] remote [local] Resume download file
rename oldpath newpath Rename remote file
reput [-fpR] local [remote] Resume upload file
rm path Delete remote file
rmdir path Remove remote directory
symlink oldpath newpath Symlink remote file
version Show SFTP version
!command Execute 'command' in local shell
! Escape to local shell
? Synonym for help
Refer sftp man page for further reading.
$ man sftp
# Exit the SFTP Session
Finally, you can exit the sftp using the bye
, exit
, or quit
:
sftp> exit
$
# Conclusion
In this guide we managed explore basic operations that can be done on an SFTP server