ssh登陆过程分析和openssh的编译、使用方法.doc

ssh登陆过程分析和openssh的编译、使用方法.doc

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
ssh登陆过程分析和openssh的编译、使用方法

h是安全的shell程序 【认证原理】 有2种认证方式 (一) 基于账号和口令的验证方式 (二) 基于公钥和私钥的验证方式 ssh的登录过程分为5个阶段 1、版本号协商阶段 2、密钥和算法协商阶段 3、认证阶段 4、会话请求阶段 5、会话交互阶段 《1》版本号协商阶段 服务端打开端口22,等待客户连接。 客户端向服务端发起TCP连接,连接建立后,服务端向客户端发送第一个报文,包括版本标志字符串,格式为“协议版本号 次协议版本号软件版本号”。 客户端收到报文后,解析协议版本号,如果服务端的协议版本号比自己的低,且客户端能支持服务端的低版本,就使用服务端的协议号,否则使用自己的协议版本号。 客户端回复服务端一个报文,包含了客户端决定使用的协议版本号。 服务端比较客户端发过来的版本号,决定是否能同客户端交互。 如果协商成功,就进入密钥和算法协商阶段。否则服务端断开TCP连接。 《2》密钥和算法协商阶段 服务端和客户端分别发送算法协商报文给对方,报文中包含自己支持的公钥算法列表、加密算法列表、消息验证码算法列表、压缩算法列表等。 服务端和客户端根据对方和自己支持的算法得出最终使用的算法。 服务端和客户端利用DH交换算法、主机密钥对等参数,生成会话密钥和会话ID。 c公 客户端公钥 c密 客户端密钥 s公 服务端公钥 s密 服务端密钥 在版本号协商阶段完成后: 服务端将 s公 发送给客户端。 服务端生成会话ID ,设为 id ,发送给客户端。 客户端生成会话密钥,设为 key ,并计算 res = id 异或 key。 客户端将 res 用 s公 进行加密,将结果发送给服务端。 服务端用 s密 进行解密,得到 res。 服务器计算 res 异或 id,得到 key。 至此服务端和客户端都知道了会话密钥和会话ID,以后的数据传输都使用会话密钥进行加密和解密。 《3》认证阶段 基于账号和口令的验证方式: 客户端使用密钥和算法协商阶段生成的会话密钥加密账号、认证方法、口令,将结果发送给服务器。 服务端使用获得的会话密钥解密报文,得到账号和口令。 服务端对这个账号和口令进行判断,如果失败,向客户端发送认证失败报文,其中包含了可以再次认证的方法列表。 客户端从认证方法列表中选择一种方法进行再次认证。 这个过程反复进行,直到认证成功或者认证次数达到上限,服务端关闭本次TCP连接。 基于公钥和私钥的验证方式: 使用ssh-keygen程序生成公钥 id_dsa.pub 和私钥 id_dsa,一般是在客户端上生成,然后把 id_dsa.pub 通过某种方式发送给服务端。 服务端放在将要远程登录过来的那个账号的目录的.ssh目录下面。 客户端使用密钥和算法协商阶段生成的会话密钥加密账号、认证方法、id_dsa.pub,将结果发送给服务端。 服务端使用会话密钥解密报文,得到账号、id_dsa.pub。 服务端在这个账号的目录的.ssh目录下找对应的公钥,如果没有找到,发送失败消息给客户端,如果找到,比较客户发送过来的这个公钥和找到的公钥,如果内容相同,服务端生成一个随机的字符串,简称“质询”,然后使用找到的公钥加密这个质询,然后使用会话密钥再次加密。 服务端把这个双重加密的数据发送给客户端。 客户端使用会话密钥解密报文,然后使用id_dsa再次解密数据,得到质询。 客户端使用会话密钥加密质询,发送给服务端。 服务端使用会话密钥解密报文,得到质询,判断是不是自己生成的那个质询,如果不相同,发送失败消息给客户端,如果相同,认证通过。 【编译步骤】 openssh是一个开源的SSH程序,包括服务端和客户端 下载地址:/ openssh依赖openssl 下载地址:/ 首先编译、安装openssl tar -zxvf openssl-1.0.0d.tar.gz mkdir /usr/local/openssl-1.0.0d cd openssl-1.0.0d ./configure --prefix=/usr/local/openssl-1.0.0d make make install 然后编译、安装openssh tar -zxvf openssh-2.1.1p4.tar.gz mkdir /usr/local/openssh-2.1.1p4 ./configure --prefix=/usr/local/openssh-2.1.1p4 --with-ssl-dir=/usr/local/openssl-1.0.0d --with-ldflags=-lcrypt make的时候会报错: “sshconnect1.c MD5_CTX 类型没有定义,MD5Init MD5Update MD5Final 找不到定义” 这个时候需要下载md5.h m

文档评论(0)

wnqwwy20 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:7014141164000003

1亿VIP精品文档

相关文档