Transfer files on linux
Set Up a Simple Python Webserver
For the examples using curl
and wget
we need to download from a web-server. This is an easy way to set up a web-server. This command will make the entire folder, from where you issue the command, available on port 9999.
Wget
You can download files using wget
like this:
Curl
Netcat
Another easy way to transfer files is by using netcat.
If you can't have an interactive shell it might be risky to start listening on a port, since it could be that the attacking-machine is unable to connect. So you are left hanging and can't do ctr-c
because that will kill your session.
So instead you can connect from the target machine like this.
On attacking machine:
On target machine:
You can of course also do it the risky way, the other way around:
So on the victim-machine we run nc
like this:
And on the attacking machine we send the file like this:
I have sometimes received this error:
I have just run this command instead:
With php
Ftp
If you have access to a ftp-client to can of course just use that. Remember, if you are uploading binaries you must use binary mode, otherwise the binary will become corrupted!!!
Tftp
On some rare machine we do not have access to nc
and wget
, or curl
. But we might have access to tftp
. Some versions of tftp
are run interactively, like this:
If we can't run it interactively, for whatever reason, we can do this trick:
SSH - SCP
If you manage to upload a reverse-shell and get access to the machine you might be able to enter using ssh. Which might give you a better shell and more stability, and all the other features of SSH. Like transferring files.
So, in the /home/user
directory you can find the hidden .ssh
files by typing ls -la
. Then you need to do two things.
Create a new keypair
You do that with:
then you enter a name for the key.
Enter file in which to save the key (/root/.ssh/id_rsa): nameOfMyKey Enter passphrase (empty for no passphrase): Enter same passphrase again:
This will create two files, one called nameOfMyKey
and another called nameOfMyKey_pub
. The one with the _pub
is of course your public key. And the other key is your private.
Add your public key to authorized_keys.
Now you copy the content of nameOfMyKey_pub
. On the compromised machine you go to ~/.ssh
and then run add the public key to the file authorized_keys. Like this
Log in.
Now you should be all set to log in using your private key. Like this
SCP
Now we can copy files to a machine using scp
Last updated