手机版
你好,游客 登录 注册 搜索
背景:
阅读新闻

SSH密钥认证原理

[日期:2014-03-10] 来源:Linux社区  作者:Linux [字体: ]

所谓的密钥认证,实际上是使用一对加密字符串,一个称为公钥(public key), 任何人都可以看到其内容,用于加密;另一个称为密钥(private key),只有拥有者才能看到,用于解密。 通过公钥加密过的密文使用密钥可以轻松解密,但根据公钥来猜测密钥却十分困难。

ssh 的密钥认证就是使用了这一特性。服务器和客户端都各自拥有自己的公钥和密钥。 为了说明方便,以下将使用这些符号。
Ac 客户端公钥
Bc 客户端密钥
As 服务器公钥
Bs 服务器密钥
在认证之前,客户端需要通过某种方法将公钥 Ac 登录到服务器上。
认证过程分为两个步骤。
1. 会话密 钥(session key)生成
1. 客户端 请求连接服务器,服务器将 As 发送给客户端。
2. 服务器生成会话ID(session id),设为 p,发送给客户端。
3. 客户端生成会话密钥(session key),设为 q,并计算 r = p xor q。
4. 客户端将 r 用 As 进行加密,结果发送给服务器。
5. 服务器用 Bs 进行解密,获得 r。
6. 服务器进行 r xor p 的运算,获得 q。
7. 至此服务器和客户端都知道了会话密钥q,以后的传输都将被 q 加密。
2. 认证
1. 服务器 生成随机数 x,并用 Ac 加密后生成结果 S(x),发送给客户端
2. 客户端使用 Bc 解密 S(x) 得到 x
3. 客户端计算 q + x 的 md5 值 n(q+x),q为上一步得到的会话密钥
4. 服务器计算 q + x 的 md5 值 m(q+x)
5. 客户端将 n(q+x) 发送给服务器
6. 服务器比较 m(q+x) 和 n(q+x),两者相同则认证成功

CentOS 下SSH无密码登录的配置 http://www.linuxidc.com/Linux/2012-05/61346.htm

Linux下实现SSH无密码验证登陆 http://www.linuxidc.com/Linux/2014-01/95917.htm

Ubuntu和CentOS如何配置SSH使得无密码登陆 http://www.linuxidc.com/Linux/2014-01/94794.htm

linux
相关资讯       SSH密钥  SSH密钥认证 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款