简介
SSH (Secure Shell,安全外壳) 是一种网络安全协议,通过加密和认证机制实现安全的访问和文件传输等业务。
SSH 的端口号是什么?
当 SSH 应用于 STelnet , SFTP 以及 SCP 时,使用的默认 SSH 端口都是 22 。当 SSH 应用于 NETCONF 时,可以指定 SSH 端口是 22 或者 830 。SSH 端口支持修改,更改后当前所有连接都会断开, SSH 服务器开始侦听新的端口。
SSH 是如何工作的?
- 连接建立
SSH 服务器在指定的端口侦听客户端的连接请求,在客户端向服务器发起连接请求后,双方建立一个 TCP 连接。
- 版本协商
SSH 协议目前存在 SSH1.X (SSH2.0 之前的版本) 和 SSH2.0 版本。SSH 2.0 协议相比 SSH1.X 协议来说,在结构上做了拓展,可以支持更多的认证方法和密钥交换方式,同时提高了服务能力。SSH 服务器和客户端通过协商确定最终使用的 SSH 版本。
- 算法协商
SSH 支持多种加密算法,双方根据各自支持的算法,协商出最终用于产生会话密钥的密钥交换算法、用于数据信息加密的加密算法、用于进行数字签名和认证的公钥算法以及用于数据完整性保护的 HMAC 算法。
- 密钥交换
服务器和客户端通过密钥交换算法,动态生成共享的会话密钥和会话 ID ,建立加密通道。会话密钥主要用于后续数据传输的加密,会话 ID 用于在认证过程中标识该 SSH 连接。
- 用户认证
SSH 客户端向服务器端发起认证请求,服务器端对客户端进行认证。 SSH 支持以下集中认证方式:
- 密码(password)认证:客户端通过用户名和密码的方式进行认证,将加密后的用户名和密码发送给服务器,服务器解密后与本地保存的用户名和密码进行对比,并向客户端返回认证成功或失败的消息。
- 密钥(publickey)认证:客户端通过用户名、公钥以及公钥算法等信息来与服务器进行认证。
- password - publickey 认证:指用户需要同时满足密码认证和秘钥认证才能登录。
- all 认证:只要满足密码认证和密钥认证其中一种即可。
- 会话请求
认证通过后,SSH 客户端向服务器端发送会话请求,请求服务器提供某种类型的服务,即请求与服务器建立相应的会话。
- 会话交互
会话建立后,SSH 服务器端和客户端在该会话上进行数据信息的交互。
使用 PuTTY 和 OpenSSH SSH密钥
-
PuTTY 是 Windows 上经典的免费 SSH 连接工具,通常用于使用 SSH 协议远程登录设备,最新版本可以在 PuTTY 官网下载。
-
OpenSSH 是 SSH 协议的开源实现,支持在 Unix 操作系统上运行,最新版本可以在 OpenSSH 官网下载。目前 Windows 10 已经包含 OpenSSH 客户端和服务器软件,可在 “设置----应用----应用与功能----可选功能” 中搜索安装。
-
SSH 密钥
- 对称加密和非对称加密
提高安全性的基本方式就是加密,加密算法通过密钥将明文转换为密文进行安全传输。SSH 在工作过程中结合使用了对称加密和非对称加密两种算法,通过实现生成的 SSH 密钥来保证信息传输的安全性。
对称加密算法,即为发送方和接收方同用一个密钥进行加密和解密。SSH 连接建立过程中生成的会话密钥就是对称密钥,该对称密钥是由客户端和服务器端基于共享的部分信息和各自的私有数据使用密钥交换算法分别生成的。因为对称加密算法加密的速度很快,所以适用于传输大量数据的场景。
非对称加密的发送和接收需要使用一对关联的 SSH 密钥、公钥和私钥。私钥由生成的一方自己保管,公钥可以发送给任何请求通信的其他人。发送方用收到的公钥对自己的通信内容进行加密,只有接收方可以使用私钥进行解密获取通信内容。非对称加密的私钥不需要暴露在网络中,安全性大大增加,但是加解密的速度比对称密钥慢的多。
SSH 连接过程中的两个阶段使用了非对称加密。一个是在密钥交换阶段,服务器和客户端都生成了自己临时的公钥和私钥,用于计算出同一个用于后续加密通信内容的会话密钥。另外一个就是在用户认证阶段,利用只有匹配的私钥可以唯一解密公钥加密的内容这一特点,通过客户端的公钥私钥对验证客户端的身份。
- 密钥认证
SSH用户认证最基本的两种方式是密码认证和密钥认证。密码认证是将自己的用户名和密码发送给服务器进行认证,这种方式比较简单,且每次登录都需要输入用户名和密码。密钥认证使用公钥私钥对进行身份验证,实现安全的免密登录,是一种广泛使用且推荐的登录方式。密钥认证的基本原理是服务器端使用客户端的公钥对随机内容加密,客户端使用自己的私钥解密并发送给服务器以证实自己的身份,具体的过程见下图。
SSH 密钥认证登录流程
- 在进行 SSH 连接之前,SSH 客户端需要先生成自己的公钥私钥对,并将自己的公钥存放在 SSH 服务器上。
- SSH 客户端发送登录请求,SSH 服务器就会根据请求中的用户名等信息在本地搜索客户端的公钥,并用这个公钥加密一个随机数发送给客户端。
- 客户端使用自己的私钥对返回信息进行解密,并发送给服务器。
- 服务器验证客户端解密的信息是否正确,如果正确则认证通过。