Remote Access

Termux is capable of accessing remote devices by using some common tools. It is also possible to turn a device running Termux into remote controlled server.

= FTP =

To start FTP server you have to run `ftpd` via `tcpsvd`

Example:

$ tcpsvd -vE 0.0.0.0 1024 ftpd /

This will start an FTP server on port 1024 from the `/` directory

Using a port number lower than 1024 on a non-rooted device will result in the following error message:

tcpsvd: bind: Permission denied

Then you can connect to Termux from another device:

$ ftp 192.168.1.3 1024

Security warning: this FTP server supports only anonymous login, so there is no authentication and anyone can connect to your device and do nasty things (like deleting files). Use it only in your own network or use SFTP.

= SSH =

Using the SSH client
By installing the openssh package (by executing apt install openssh) you may SSH into remote systems, optionally putting private keys or configuration under $HOME/.ssh/.

If you wish to use an SSH agent to avoid entering passwords, the Termux openssh package provides a wrapper script named ssha (note the ‘a’ at the end) for ssh which:


 * 1) Starts the ssh agent if necessary (or connect to it if already running).
 * 2) Runs ssh-add if necessary.
 * 3) Runs ssh with the provided arguments.

This means that the agent will prompt for a key password at first run, but remember the authorization for subsequent runs.

Using the SSH server
The sshd server is included in the openssh package and allows you to connect to your Android device over ssh.

Start the server by executing `sshd` (which will start it on the default port 8022) and run `logcat -s 'syslog:*'` to view the log output from the server process. Execute `pkill sshd` to stop the server.

Since Termux is a single-user system you may connect as any user - regardless of your specified username you will login as the only Termux user available.

The Termux sshd binary does not support password logins, so a key needs to be authorized in `~/.ssh/authorized_keys` before connecting. Use `ssh-keygen` to generate a new one if desired.

Using the SFTP
Example: $ sftp -P 8022 192.168.1.20

= MOSH = Remote terminal application that allows roaming, supports intermittent connectivity, and provides intelligent local echo and line editing of user keystrokes.

Mosh is a replacement for interactive SSH terminals. It's more robust and responsive, especially over Wi-Fi, cellular, and long-distance links.

= Accessing Termux from the Internet =

It is possible to access your device over the Internet even if you are behind NAT device (e.g. Wi-Fi router or on mobile network). However, this method requires setting up a Tor Onion Service, it allows you to access your web sites or SSH via standard ports without rooting (a feature of Tor Onion Services).

Installing needed packages
The main package is tor. Install it by running this command: pkg install tor

You may want to install a `torsocks` for accessing the Tor Network: pkg install torsocks

Setting up Onion Service
You will have to modify the default configuration file of tor. Here is an example of configuring SSH Onion Service: SOCKSPort 127.0.0.1:9050
 * 1) Enable TOR SOCKS proxy

HiddenServiceDir /data/data/com.termux/files/home/.tor/hidden_ssh HiddenServicePort 22 127.0.0.1:8022
 * 1) Hidden Service: SSH

Then you need to make a directory where information about Hidden Service will be stored: mkdir -p ~/.tor/hidden_ssh

Now you can execute in console. If start was successfull, you can get your onion service hostname: cat ~/.tor/hidden_ssh/hostname Output should be like this:

Accessing your service
First of all make sure that on client device `tor` is running and you have all necessary software for accessing Tor Network (in this case package `torsocks`).

To access the onion service created in previous step, run this: torsocks ssh g3yv3tvqrbow7koz.onion

If everything is ok, the output should be like this: The authenticity of host 'g3yv3tvqrbow7koz.onion (127.42.42.0)' can't be established. ED25519 key fingerprint is SHA256:WGualHEq7SJdvVeXgy8a+btPQCd7uxTeXjlWdHHLwLc. Are you sure you want to continue connecting (yes/no)?

Remember, `tor` should be running on both (client/server) sides, otherwise you will get connection errors. You can configure other servers (e.g. Nginx) in the same way as shown in above example for SSH.

Learn more about Onion Services
Better explanation about Onion Services and other Tor-related things you can found at torproject.org.

= See Also =

https://termux.com/ftp/ Run an SSH server on your Android with Termux