目录
1. SSH公私钥与SSH公私钥后门介绍
1.1 SSH公私钥介绍
SSH(Secure Shell)公私钥对是一种用于认证的加密技术,它允许用户通过持有私钥来远程登录服务器,而无需输入密码。这种认证方式比传统的密码认证更安全,因为它依赖于加密技术来验证用户的身份。
1.1.1 公钥和私钥的基本概念
-
公钥(Public Key):这是一个可以公开的密钥,通常用于加密数据或验证签名。在SSH认证中,公钥用于加密会话密钥,确保只有持有对应私钥的用户才能解密并建立连接。
-
私钥(Private Key):这是一个必须保密的密钥,用户用它来解密接收到的数据或对数据进行签名。在SSH认证中,私钥用于解密由公钥加密的会话密钥,从而建立安全的SSH连接。
1.1.2 SSH公私钥认证的工作原理(很重要)
-
密钥生成:用户使用SSH密钥生成工具(
ssh-keygen
)创建一对密钥,即公钥和私钥。 -
公钥部署:用户将公钥复制到服务器的
~/.ssh/authorized_keys
文件中,这个文件存储了允许登录到该服务器的所有公钥。 -
认证过程:
- 当用户尝试使用SSH客户端连接服务器时,服务器会从
authorized_keys
文件中读取公钥。 - 服务器使用这个公钥加密一个会话密钥,并将其发送给客户端。
- SSH客户端使用对应的私钥解密会话密钥,然后使用这个会话密钥与服务器建立加密的SSH连接。
- 当用户尝试使用SSH客户端连接服务器时,服务器会从
-
连接建立:如果客户端能够成功解密会话密钥并建立连接,服务器就知道客户端持有正确的私钥,从而验证了用户的身份。
1.2 SSH公私钥后门介绍
SSH公私钥后门是一种利用SSH协议的公钥认证机制来实现未授权访问的技术。在SSH协议中,除了传统的密码认证方式外,还可以使用公钥和私钥对进行认证。用户将公钥放置在服务器的~/.ssh/authorized_keys文件中,之后使用对应的私钥即可登录服务器,无需输入密码。
SSH公私钥后门的关键在于攻击者通过某种手段获取到服务器的写入权限,将自己的公钥添加到authorized_keys文件中,或者篡改已有的公钥。这样,攻击者就可以使用对应的私钥在不被察觉的情况下登录服务器。(就是在有权限的情况下,自己增加了一个额外的登录认证的方式)
2. 如何在已拿下控制权限的主机创建后门
2.1 使用 Xshell 生成公钥与私钥
在攻击机上使用 Xshell 生成私钥,按照如图所示选择“新建用户密钥生成向导”