Differences
This shows you the differences between the selected revisions of the page.
2014-03-05 | 2014-06-13 | ||
GSSAPI is not MIT Kerberos only anymore + linking to ui_login_authentication#gssapi (martin) | verifying the host key section moved to ssh_verifying_the_host_key (martin) | ||
Line 15: | Line 15: | ||
===== Verifying the Host Key ===== | ===== Verifying the Host Key ===== | ||
- | If you are using WinSCP to connect to a server for the first time, you will probably see a message looking something like this: | + | To prevent man-in-the-middle attacks, each SSH server has a unique identifying code, called a host key. These keys prevent a server from forging another server's key. If you connect to a server for the first time or if the server presets a different key then previously, WinSCP will prompt you to [[ssh_verifying_the_host_key|verify the key]]. |
- | + | ||
- | The server's host key was not found in the cache. You have no guarantee that the | + | |
- | server is the computer you think it is. | + | |
- | The server's rsa2 key fingerprint is: | + | |
- | ssh-rsa 2048 94:3c:9e:2b:23:df:bd:53:b4:ad:f1:5f:4e:2f:9d:ba | + | |
- | + | ||
- | This is a feature of the SSH protocol. It is designed to protect you against a network attack known as spoofing: secretly redirecting your connection to a different computer, so that you send your password to the wrong machine. Using this technique, an attacker would be able to learn the password that guards your login account, and could then log in as if they were you and use the account for their own purposes. | + | |
- | + | ||
- | To prevent this attack, each server has a unique identifying code, called a host key. These keys prevent a server from forging another server's key. If you connect to a server and you receive an unexpected host key, WinSCP can warn you that the server may have been switched and that a spoofing attack might be underway. | + | |
- | + | ||
- | WinSCP records the host key for each server you connect to, in the [[config|configuration storage]]. Every time you connect to a server, it compares the server's host key to the host key you received the last time you connected. If the keys differ, you will receive a warning and a chance to abandon your connection before you enter any private information such as a password. | + | |
- | + | ||
- | However, when you connect to a server for the first time, WinSCP has no way of telling whether the host key is the right one or not. So it gives the warning shown above, and asks you whether you want to trust this host key or not. | + | |
- | + | ||
- | Whether or not to trust the host key is your choice. If you are connecting within a company network, you might feel that all the network users are on the same side and spoofing attacks are unlikely, so you might choose to trust the key without checking it. If you are connecting across a hostile network (such as the Internet), you should check with your system administrator, perhaps by telephone or in person. (Some modern servers have more than one host key. If the system administrator sends you more than one fingerprint, you should make sure the one WinSCP shows you is on the list, but it doesn't matter which one it is.) ((&puttydoccite)) | + | |
- | + | ||
- | Once the key is verified, you can see it during all future sessions on [[ui_fsinfo|Server and Protocol Information Dialog]]. | + | |
- | + | ||
- | Learn also how to [[scripting#hostkey|accept host key automatically in script]]. | + | |
- | + | ||
- | [[administration|System administrator can restrict]] connection to server without having their host keys accepted in advance. | + | |
- | + | ||
- | //Do not confuse host public key with your [[public_key|private/public key pair used for authentication]].// | + | |
===== Encryption in SSH ===== | ===== Encryption in SSH ===== |