Howto: Difference between revisions

From FileZilla Wiki
Jump to navigationJump to search
(→‎SFTP using SSH2: Key based authentication: Copy edited (e.g. ref. <https://en.wikipedia.org/wiki/PuTTY> and <https://en.wikipedia.org/wiki/Secure_Shell>).)
Line 2: Line 2:


There are three mechanisms for use of the FileZilla client with SSH2 keys.
There are three mechanisms for use of the FileZilla client with SSH2 keys.
# In the profile settings in the Site Manager of the FileZilla client. If the SFTP Protocol is specified, it is possible to specify the Logon Type as "Key File" and specify the location of the private key file (in putty's .ppk or openssh's .pem format) The user is prompted for the key file's password if necessary, which may optionally be cached by Filezilla until it is next shut down.
# In the profile settings in the Site Manager of the FileZilla client. If the SFTP Protocol is specified, it is possible to specify the Logon Type as "Key File" and specify the location of the private key file (in PuTTY's .ppk or openssh's .pem format) The user is prompted for the key file's password if necessary, which may optionally be cached by FileZilla until it is next shut down.
# In the Edit - Settings menu of the FileZilla client, you can [Add key file...] under Connection - SFTP, and FileZilla can then use the public key authentication in the site manager with the 'Interactive' Logontype on connection. Note: Importing a site's '''public''' key is not supported.
# In the Edit - Settings menu of the FileZilla client, you can [Add key file...] under Connection - SFTP, and FileZilla can then use the public key authentication in the site manager with the 'Interactive' Logontype on connection. Note: Importing a site's '''public''' key is not supported.
# (Windows only) Using the  excellent [http://www.chiark.greenend.org.uk/~sgtatham/putty/ PuTTY] tools. To allow the use of RSA / DSA key files with Filezilla, you'll need to download two more tools from PuTTY: Pageant and (assuming your key file isn't already in PPK format) PuTTYgen.
# (Windows only) Using the  excellent [http://www.chiark.greenend.org.uk/~sgtatham/putty/ PuTTY] tools. To allow the use of RSA / DSA key files with FileZilla, you'll need to download two more tools from PuTTY: Pageant and (assuming your key file isn't already in PPK format) PuTTYgen.


=== generate ssh key ===
=== Generate the SSH key ===
Filezilla can use existing ssh key, but cannot generate ssh key itself.
FileZilla can use an existing SSH key, but it cannot generate the SSH key itself.
you can generate ssh key with putty or openssh. (now openssh is built-in in windows.)
You can generate an SSH key with PuTTY or OpenSSH. (Now OpenSSH is built-in in windows.)


* putty: use GUI program PuTTYgen to generate ssh key.
* PuTTY: use GUI program PuTTYgen to generate an SSH key.
* openssh: open cmd.exe or powershell, type command <code>ssh-keygen -t rsa -b 2048 -f my-ssh-key</code> will generate private key <code>my-ssh-key</code> and public key <code>my-ssh-key.pub</code> .
* OpenSSH: open cmd.exe or PowerShell, and type command <code>ssh-keygen -t rsa -b 2048 -f my-ssh-key</code>. It will generate a private key, <code>my-ssh-key</code>, and a public key, <code>my-ssh-key.pub</code>.


after generate new key, you need to add the public key to the file <code>~/.ssh/authorized_keys</code> ,
After generating a new key, you need to add the public key to the file <code>~/.ssh/authorized_keys</code>,
or concact the system admin, then you can login with private key.
or contact the system administrator, and then you can log in with a private key.


=== Using ssh key with putty's ssh agent ===
=== Using the SSH key with PuTTY's SSH agent ===
If your key file is already in PuTTY's PPK format you can skip this paragraph. However if your key is in OpenSSH format, you first need to convert it to PuTTY's PPK format. To do this, launch PuTTYgen and from the "Conversions" menu, select the "Import key" option. Select your key and follow the prompts to enter your pass phrase. Save your private key.
If your key file is already in PuTTY's PPK format you can skip this paragraph. However, if your key is in OpenSSH format, you first need to convert it to PuTTY's PPK format. To do this, launch PuTTYgen and from the "Conversions" menu, select the "Import key" option. Select your key and follow the prompts to enter your pass phrase. Save your private key.


Now run Pageant. In your system tray, you'll see the Pageant icon appear. Right-click the icon and select "Add Key" and select your private key (PPK) file. Follow the prompt to enter your pass phrase and you're done.
Now run Pageant. In your system tray, you'll see the Pageant icon appear. Right-click the icon and select "Add Key" and select your private key (PPK) file. Follow the prompt to enter your pass phrase and you're done.
Line 31: Line 31:
==== On a Mac ====
==== On a Mac ====


If for some reason you are not using ssh-agent and on a Mac, don't worry about ssh key conversion. Just import your key via Settings and then use Normal mode in your site connection definition. The imported key will get used.
If for some reason you are not using ssh-agent and on a Mac, don't worry about SSH key conversion. Just import your key via Settings and then use Normal mode in your site connection definition. The imported key will get used.


The following instructions assume you have a working SSH configuration which allows you to ssh to the same host without a password. They are adapted from [http://superuser.com/questions/280808/filezilla-on-mac-sftp-with-passwordless-authentication a thread on superuser.com] and summarized here so you don't have to search through a lot of dead ends:
The following instructions assume you have a working SSH configuration which allows you to ssh to the same host without a password. They are adapted from [http://superuser.com/questions/280808/filezilla-on-mac-sftp-with-passwordless-authentication a thread on superuser.com] and are summarized here so you don't have to search through a lot of dead ends:


# In FileZilla->Settings.. select Connection->SFTP
# In FileZilla &nbsp; ''Settings...'', select Connection &nbsp; SFTP
# Press the Add key file... button
# Press the ''Add key file...'' button
# Press Command-Shift-G to bring up a path selection window and type "~/.ssh"
# Press Command-Shift-G to bring up a path selection window and type "~/.ssh"
# Select the "id_rsa" key file and click Open (this imports the key)
# Select the "id_rsa" key file and click Open (this imports the key)
# Click OK to close the Settings dialog
# Click OK to close the Settings dialog
# Open File->Site Manager...
# Open menu ''File'' &nbsp; ''Site Manager...''
# Select the site with which you want to use the key
# Select the site with which you want to use the key
# Choose Protocol "SFTP" and select Logon Type "Normal". Don't worry about a password if you key file doesn't have a password
# Choose Protocol "SFTP" and select Logon Type "Normal". Don't worry about a password if you key file doesn't have a password
# Click Connect and you'll see your files
# Click ''Connect'' and you'll see your files

Revision as of 11:17, 25 April 2020

SFTP using SSH2: Key based authentication

There are three mechanisms for use of the FileZilla client with SSH2 keys.

  1. In the profile settings in the Site Manager of the FileZilla client. If the SFTP Protocol is specified, it is possible to specify the Logon Type as "Key File" and specify the location of the private key file (in PuTTY's .ppk or openssh's .pem format) The user is prompted for the key file's password if necessary, which may optionally be cached by FileZilla until it is next shut down.
  2. In the Edit - Settings menu of the FileZilla client, you can [Add key file...] under Connection - SFTP, and FileZilla can then use the public key authentication in the site manager with the 'Interactive' Logontype on connection. Note: Importing a site's public key is not supported.
  3. (Windows only) Using the excellent PuTTY tools. To allow the use of RSA / DSA key files with FileZilla, you'll need to download two more tools from PuTTY: Pageant and (assuming your key file isn't already in PPK format) PuTTYgen.

Generate the SSH key

FileZilla can use an existing SSH key, but it cannot generate the SSH key itself. You can generate an SSH key with PuTTY or OpenSSH. (Now OpenSSH is built-in in windows.)

  • PuTTY: use GUI program PuTTYgen to generate an SSH key.
  • OpenSSH: open cmd.exe or PowerShell, and type command ssh-keygen -t rsa -b 2048 -f my-ssh-key. It will generate a private key, my-ssh-key, and a public key, my-ssh-key.pub.

After generating a new key, you need to add the public key to the file ~/.ssh/authorized_keys, or contact the system administrator, and then you can log in with a private key.

Using the SSH key with PuTTY's SSH agent

If your key file is already in PuTTY's PPK format you can skip this paragraph. However, if your key is in OpenSSH format, you first need to convert it to PuTTY's PPK format. To do this, launch PuTTYgen and from the "Conversions" menu, select the "Import key" option. Select your key and follow the prompts to enter your pass phrase. Save your private key.

Now run Pageant. In your system tray, you'll see the Pageant icon appear. Right-click the icon and select "Add Key" and select your private key (PPK) file. Follow the prompt to enter your pass phrase and you're done.

Now simply launch FileZilla and connect to your server using SFTP using SSH2 with a username and an empty password. Don't forget to close pageant when you're done.

This also works with the portable versions of FileZilla and PuTTY tools.

Alternative Method

FileZilla supports the standard SSH agents. If your SSH agent is running, the SSH_AUTH_SOCK environment variable should be set. (Note, the "Normal" logon type should be set for the server in order to use the SSH agent socket.)

On a Mac

If for some reason you are not using ssh-agent and on a Mac, don't worry about SSH key conversion. Just import your key via Settings and then use Normal mode in your site connection definition. The imported key will get used.

The following instructions assume you have a working SSH configuration which allows you to ssh to the same host without a password. They are adapted from a thread on superuser.com and are summarized here so you don't have to search through a lot of dead ends:

  1. In FileZilla   Settings..., select Connection   SFTP
  2. Press the Add key file... button
  3. Press Command-Shift-G to bring up a path selection window and type "~/.ssh"
  4. Select the "id_rsa" key file and click Open (this imports the key)
  5. Click OK to close the Settings dialog
  6. Open menu File   Site Manager...
  7. Select the site with which you want to use the key
  8. Choose Protocol "SFTP" and select Logon Type "Normal". Don't worry about a password if you key file doesn't have a password
  9. Click Connect and you'll see your files