问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

图解SSH原理

发布网友 发布时间:2022-10-21 09:39

我来回答

1个回答

热心网友 时间:2024-09-17 23:22

SSH 是一种协议标准,其目的是实现安全远程登录以及其它安全网络服务

在讨论SSH的原理和使用前,我们需要分析一个问题:为什么需要SSH?

从1.1节SSH的定义中可以看出,SSH和telnet、ftp等协议主要的区别在于安全性。这就引出下一个问题:如何实现数据的安全呢?首先想到的实现方案肯定是对数据进行加密。加密的方式主要有两种:

所谓对称加密,指加密解密使用同一套秘钥。如下图所示:

对称加密的加密强度高,很难破解。但是在实际应用过程中不得不面临一个棘手的问题:如何安全的保存密钥呢?尤其是考虑到数量庞大的Client端,很难保证密钥不被泄露。一旦一个Client端的密钥被窃据,那么整个系统的安全性也就不复存在。为了解决这个问题,非对称加密应运而生。非对称加密有两个密钥:“公钥”“私钥”

下面看下使用非对称加密方案的登录流程:

上述流程会有一个问题:Client端如何保证接受到的公钥就是目标Server端的?,如果一个攻击者中途拦截Client的登录请求,向其发送自己的公钥,Client端用攻击者的公钥进行数据加密。攻击者接收到加密信息后再用自己的私钥进行解密,不就窃取了Client的登录信息了吗?这就是所谓的 中间人攻击

从上面的描述可以看出,问题就在于如何对Server的公钥进行认证?在https中可以通过CA来进行公证,可是SSH的publish keyprivate key都是自己生成的,没法公证。只能通过Client端自己对公钥进行确认。通常在第一次登录的时候,系统会出现下面提示信息:

上面的信息说的是:无法确认主机ssh-server.example.com(12.18.429.21)的真实性,不过知道它的公钥指纹,是否继续连接?

如果输入yes后,会出现下面信息:

该host已被确认,并被追加到文件known_hosts中,然后就需要输入密码,之后的流程就按照图1-3进行。

在上面介绍的登录流程中可以发现,每次登录都需要输入密码,很麻烦。SSH提供了另外一种可以免去输入密码过程的登录方式:公钥登录。流程如下:

经过上面的原理分析,下面三行命令的含义应该很容易理解了:

ssh-keygen是用于生产密钥的工具。

首先看下面~/.ssh中的四个文件:

四个角色的关系如下图所示:

本文以图文方式对SSH原理进行解析(主要指远程登录,没有涉及端口转发等功能)。同时分析了非对称加密的特性,以及在实践过程中如何对加密操作进行改进。

感谢@ 风笑天2013 指正,下面关于SSH的known_hosts机制做如下更正:

known_hosts中存储是已认证的远程主机host key,每个SSH Server都有一个secret, unique ID, called a host key

当我们第一次通过SSH登录远程主机的时候,Client端会有如下提示:

此时,如果我们选择yes,那么该host key就会被加入到Client的known_hosts中,格式如下:

最后探讨下为什么需要known_hosts,这个文件主要是通过Client和Server的双向认证,从而避免中间人(man-in-the-middle attack)攻击,每次Client向Server发起连接的时候,不仅仅Server要验证Client的合法性,Client同样也需要验证Server的身份,SSH client就是通过known_hosts中的host key来验证Server的身份的。

灰常感谢大家,希望收到更多的评论指正。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
临沂比较有名的男装品牌 呼伦贝尔市悦动网络科技有限公司怎么样? 呼伦贝尔中汇实业有限公司怎么样? 呼伦贝尔油玉不绝电子商务有限公司怎么样? 如何避免wps卡顿? 属鼠的男人找对象是属什么,属鼠的人和什么属相合 96年鼠的姻缘在哪年 属相相合年份运势提升 2024属鼠找对象属什么最佳 黑客攻击网站能报案吗 黑客攻击报案有用吗 为什么 2015 年底各大网站都纷纷用起了 HTTPS 关于 触祭の都 的安装问题。 一些地方话! js的正则表达式匹配1[012],1[112],2[122]是什么意思? js给a定义一个变量,让a等于012,弹出a的值为什么不是12呢 梦见秃头有什么寓意 梦见秃头是什么意思 梦见秃头周公解梦 梦见秃头有什么预兆 梦见抓到鲤鱼是好还是不好呢?谢 江苏常卅糖醋小排做法 适合客厅里的字 家里挂什么字好 大气又雅致 我叫mt微信符石怎么兑换 我叫MT怎么刷符石? 泰国风味菜怎么做 迷迭香烤红虾的家常做法大全怎么做好吃视 迷迭香烤大虾的做法,迷迭香烤大虾怎么做好吃 迷迭香盐焗大虾的做法步骤图,怎么做好吃 永恒之塔魔道装备选择~ 50级魔道学者穿什么装备好? 孩子性格软弱怎么培养 孩子性格软弱如何培养 如何克服孩子的懦弱 刚生完该子能吃茄孑饺子吗 手机拍照真实还是手机录像真实?? 青木瓜牛奶的做法 大灯调节螺丝花盘怎么拆 器材的解释及造句 excel中从左边第4个值开始取值到最后 新版QQ别人转发的这个怎么能设置不让别人看谁转发了 QQ三国我的角色在哪个区我忘了,有什么方法可以知道啊? 金鱼可以喂虾皮么 金鱼可以吃虾皮吗?有人说最好用水泡,那是热水泡呢还是冷水呢?_百度... 金鱼能喂小虾米皮吗 绿豆山药排骨粥一岁宝宝可以吃吗 年末离津怎样提取公积金? 为什么太阳会晒黑 价格指数权重表的变值部分投标人能改吗? 谁给我一些中考高考 语文答题的好词,要比较深奥的。比如诠释、旖旎、缄... 莲子和西瓜能一起吃吗 生莲子和西瓜有相克没有