I've looked on the internet for a quick step-by-step guide how to get PuTTY to use public key authentication with OpenSSH daemon and it took me some time to figure. I'm posting these instructions in case anybody else has the same needs.
Prerequisites
Make sure that your OpenSSH configuration (usually /etc/ssh/sshd_config) contains the following line:
PubkeyAuthentication yes
In my case (CentOS 5.4) it was disabled by default.
Also, you would need the full PuTTY suite which can be downloaded form here (get putty.zip).
Generating the key
This is a way to generate the key with Putty. Alternatively you can generate it with OpenSSH's ssh-keygen tool and convert it to PuTTY format.
- Start PUTTYGEN.EXE
- In the parameters box at the bottom of the window, choose type of key 'SSH-2 RSA', set the bit size to 2048.
- Click the Generate button, move the mouse over the blank area until the progres bar fills up.
- Enter your notes in the comment line (this is displayed to you when you use the key, you can change later).
- Enter key-phrase, make it long and complex, write it down in a secure place or print it and hide it somewhere in your freezer.
- Save the private key (*.ppk) in a reasonably secure filesystem location. Even if somebody gets access to your private key, they will still need your passphrase to use it.
- Copy the text from the text box under the 'Public key for pasting into OpenSSH authorized_keys file:' and paste it on one line in a new file called authorized_keys (we'll use that later). The file should contain a single line terminated by Unix-style new-line and there shall not be an empty line after it.
- Close PUTTYGEN.EXE
Associating the key with your Unix account
- Login to your unix account
- Create a .ssh directory under your home if it does not exist
- Copy the authorized_keys file there
- Do
chmod 700 ~/.ssh ; chmod 600 ~/.ssh/authorized_keys
This needs to be done for each machine you are connecting to. In this case it helps if your homw is NFS mounted.
Using the key directly
- Start PuTTY
- Specify user@host in the 'Session > Host Name' field.
- Specify the path to your private key file in the 'Connection > SSH > Auth > Private key file' box.
- Click the 'Open' button at the bottom of the PuTTY settings dialog.
- When prompted, enter your private-key pass-phrase and you will be logged in without entering your Unix password
Setting up Pageant to cache the decrypted private key
Let's look what we have done. The good thing is that our password does not travel over the wire and is not susceptible to man-in-the-middle attacks. The bad thing is that we used to enter the short and easy password of our Unix account, while now we have to enter the long and difficult pass-phrase of our key every time we establish a new Unix connection. In order to avoid this, we can use PuTTY Pageant which is SSH authentication agent (Unix equivalent is ssh-agent)
- Start PAGEANT.EXE
- Click on the computer-with-hat icon in your system tray.
- Choose the Add Key option and pick your private key (*.ppk)
- Enter your pass-phrase
- Close the pageant dialog
From now on, when establishing SSH session Putty will try to use the decrypted key from Pageant first and then fall back to password auth if none of the keys match.
You can create a shortcut, starting Pageant and passing the paths to your keys as arguments. This will start Pageant and load the keys in one step, but you will still need to specify the pass-phrase every time you do this (typically after system restart).
Keep in mind that Pageant holds the private key in memory unencrypted. If anybody captures a heap dump of the process, they can get access to your private key without knowing the pass-phrase. That's why, you might want to stop the Pageant if you are not using it for a long time or if you shae the machine in multi-user environment.
If using Pageant, you might also check the Putty option 'Connection > SSH > Auth agent forwarding', which will allow you to use your key from the remote machine on which you are logged on.