操作系统:SSH协议知识介绍

       f1839f4348a5a5403dcc37882bda2bb7.png        

今天给大家分享SSH协议相关的知识介绍,希望对大家能有所帮助!

1、SSH协议概念介绍

SSH(Secure Shell)安全外壳协议,是一种建立在应用层基础上的安全协议,通过对密码进行加密传输验证,可以在不安全的网络中对网络服务提供安全的传输环境,实现SSH客户端和SSH服务器端的连接,所以SSH是基于客户端-服务端模式。

2、SSH服务组成

SSH服务由服务端软件OpenSSH和连接客户端组成(SSH、SecureCRT,xshell等),默认端口是22。SSH是一个守护进程,负责实时监听客户端请求,并进行处理。

3、SSH协议框架组成

SSH协议框架中核心部分的三个协议:传输层协议、用户认证协议、连接协议。

  • 传输层协议(The Transport Layer Protocol):提供服务器认证,数据安全性,信息完整性等功能的支持。

  • 用户认证协议(The User Authentication Protocol):为服务器提供客户端的身份的识别。

  • 连接协议(The Connection Protocol):将加密的信息隧道复用成若干个逻辑通道,提供给更高层的应用协议使用; 各种高层应用协议可以相对地独立于SSH基本体系之外,然后依靠这个基本框架,通过连接协议使用SSH的安全机制。

       560842b63d8e29307ee3e5b2dadc34be.png        

4、SSH工作流程

4.1 版本号协商阶段

SSH目前包括 SSH1和SSH2两个版本, 双方通过版本协商确定使用的版本

  • 服务端开启22端口,等待客户端发起连接请求

  • 客户端向服务端发起TCP初始连接请求,建立后,服务端向客户端发送报文(版本标志字符串:SSH-<主协议版本号>.<次协议版本号>-<软件版本号>>)

  • 客户端收到报文后,解析数据包,如果服务端的协议版本号比自己的低,且客户端能支持服务端的低版本,就采用服务器端的低版本协议号,否则采用客户端自己的协议版本号。

  • 客户端回应服务器一个报文,包含客户端决定使用的协议版本号。服务端会比较客户端发来的版本号,决定是否能同客户端进行正常工作。

  • 协商成功,就会进入密钥和算法协商阶段,否则服务端断开TCP连接。

注意:版本号协商阶段报文都是采用明文方式传输的。

4.2 密钥和算法协商阶段

SSH支持多种加密算法, 双方根据服务端和客户端支持的算法,协商出最终使用的算法

  • 服务端和客户端分别发送算法协商报文给对方,报文中包含自己支持的公钥算法列表、加密算法列表、MAC(Message Authentication Code,消息验证码)算法列表、压缩算法列表等协商信息。

  • 服务端和客户端根据对方和自己支持的算法列表确定最终使用的算法。

  • 服务端和客户端利用 DH交换(Diffie-Hellman Exchange)算法、主机密钥对等参数,生成会话密钥和会话 ID,然后双方都拿到了相同的会话ID和会话密钥。

  • 后续数据通信,两端都会使用会话密钥进行加密和解密,从而保证了数据传送的安全

  • 认证阶段,两端会使用会话 ID用于认证过程。

注意:在协商阶段之前,服务器端已经生成 RSA或 DSA密钥对,主要用于参与会话密钥的生成。

4.3 认证阶段

SSH客户端向服务端发起认证请求, 服务端会对客户端进行认证

  • 客户端向服务端发送认证请求,认证请求信息中包含用户名、认证方法、与该认证方法相关的内容(比如:password认证时,内容为密码)。

  • 服务端对客户端进行认证,如果认证失败,会向客户端发送认证失败消息,其中也包含可以再次发起认证的方法列表。

  • 客户端从服务端返回的认证方法列表中选取一种认证方法再次进行认证。

  • 该过程反复进行, 直到认证成功或者认证次数达到上限, 服务端关闭连接为止。

4.5 会话请求阶段:

认证通过后,客户端向服务端发送会话请求

  • 服务器等待客户端的请求;

  • 认证通过后,客户端向服务器发送会话请求;

  • 服务器处理客户端的请求。请求被成功处理后, 服务端会向客户端回应 SSH_SMSG_SUCCESS包,SSH进入交互会话阶段;否则回应 SSH_SMSG_FAILURE包,表示服务器处理请求失败或者不能识别请求。

4.6 交互会话阶段

会话请求通过后,服务端和客户端可以进行信息的交互

  • 客户端将要执行的命令加密后传给服务器;

  • 服务器接收到报文,解密后执行该命令,将执行的结果加密发还给客户端;

  • 客户端将接收到的结果解密后显示到终端上.

说明:在当前阶段下,数据可以被双向传送

5、SSH的认证方式

5.1 password认证:

客户端向服务端发出 password认证请求,然后将用户名和密码加密后发送给服务器;服务器将该信息解密后得到用户名和密码的明文,与自己设备上保存的用户名和密码进行比较,并返回认证成功或失败的消息。

5.2publickey 认证:

采用数字签名的方法来认证客户端。目前,设备上可以利用RSA和 DSA两种公共密钥算法实现数字签名。

客户端发送包含用户名、公共密钥和公共密钥算法的 publickey 认证请求给服务端。服务器、端对公钥进行合法性检查,如果不合法,则直接发送失败消息;否则,服务器利用数字签名对客户端进行认证,并返回认证成功或失败的消息。

5.3. password-publickey 认证(SSH2.0)

指定该用户的认证方式为 password 和 publickey认证必须同时满足。

说明:客户端版本为 SSH1的用户只要通过其中一种认证即可登录;客户端版本为 SSH2的用户必须两种认证都通过才能登录。

5.4 any认证(SSH2.0)

指定该用户的认证方式可以是 password、 publickey中任意一种。

6、SSH常用命令

6.1 远程登录

ssh 用户名@远程主机ip:首次登陆需要下载对方公钥。

示例:ssh 192.168.1.100

6.2 远程上传

scp [需要上传文件的本地位置] root@远程主机ip:[需要保存在远程主机的路径]:从本地上传文件到远程主机

示例:scp /root/test.sh root@192.168.1.100

6.3 远程复制

scp root@远程主机ip:[远程主机文件绝对路径] [需要保存的本地位置]:从远程主机下载文件到本机

示例:scp root@192.168.1.100:/root/test.sh /root

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/270190.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

操作系统:分享Win11几个实用小技巧,赶快收藏吧

目录 1、让任务栏显示“右键菜单” 2、任务栏置顶 3、还原经典右键菜单 4、Win11版任务管理器 5、新版AltTab 6、开始菜单不再卡 7、为Edge浏览器添加云母效果 8、自动切换日/夜模式 Win11在很多地方都做了调整&#xff0c;但由于涉及到诸多旧有习惯&#xff0c;再加上前期Bug的…

2021-02-10

mysql中不等于有两种使用方式 ! 或者<> 推荐使用 <>这种方式

办公技巧:EXCEL10个常用函数介绍

目录 1、MID函数 (left right函数同理&#xff09; 2、CONCATENATE函数 3、AND函数 4、函数名称&#xff1a;DATEDIF 5、IF函数 6、COUNTIF函数 7、SUMIF函数 8、DCOUNT函数 9、ISERROR函数 10、VLOOKUP函数 EXCEL函数太多了&#xff0c;其实常用就是10多个个&#xff0c;只要…

远程工具:MobaXterm使用图文教程

目录 1、下载MobaXterm 2、安装打开MobaXterm 3、建立SSH连接到一台服务器 4、终端服务 5、sftp 文件传输服务 6、上传下载文件 MobaXterm作为一款优秀的远程连接工具&#xff0c;很多朋友在日常当中都会使用到&#xff0c;今天小编给大家介绍一下MobaXterm从下载到安装使用的图…

mysql模糊查询指定根据第几个字符来匹配

mysql模糊查询指定根据第几个字符来匹配 下图案例1中&#xff0c;查询某员工名中第三个字符位e,第五个字符为a的员工名和工资 select last_name,salary FROM employess WHERE last_name LIKE __n_l%; 案例2中&#xff0c;查询员工名中第二个字符为_的员工名,需要转义一下 S…

手机知识:手机快充取决于充电头还是数据线,看完你就懂了

目录 1、充电头方面 2、数据线方面 3、总结 手机是否支持快充主要取决于数据线和充电头是否都支持快充&#xff0c;当然前提是充电头需要和手机具备相同的快充协议&#xff0c;另外数据线可传输的最大电流也会影响手机的快充效果。 1、充电头方面 智能手机充电的过程中&#xf…

Spring系列(二):Bean注解用法介绍

目录 1、首先创建一个maven项目引入spring依赖 2、新建一个person.java 实体类 3、新建配置类 TestBeanConfig.java 4、resources 创建配置文件 5、新建测试类TestBean.java 具体展示注解方式和配置方式的示例 今天给大家介绍一下Spring中Bean注解的用法,后续的文章给大家介绍S…

ASP.NET Zero--5.配置权限

修改角色的时候&#xff0c;会有一份权限列表&#xff0c;可以给这个角色分配哪些权限&#xff0c;那如何添加一个新权限呢&#xff1f;这里以添加一个“测试”的权限为例1.打开AppPermissions.cs 【..\MyCompanyName.AbpZeroTemplate.Core\Authorization\AppPermissions.cs】文…

mysql小写转大写UPPER() 和大写转小写LOWER()

小写转大写 UPPER() 大写转小写 LOWER()

Spring系列(三):@ComponentScan注解用法介绍

目录 1、ComponentScan注解的作用 2、ComponentScan注解属性介绍 2.1 value 2.2 excludeFilters&#xff08;排除规则&#xff09; 2.3 includeFilters&#xff08;包含规则&#xff09; 2.4 FilterType属性 3、示例 3.1 各种过滤过滤规则示例 3.2 自定义过滤规则 需要新建 Tes…

手机知识:手机的快充技术是什么,看完本文你就懂了

目录 1、什么是手机快充&#xff1f; 2、目前主流的手机快充协议 2.1 PD协议 2.2 PE协议 &#xff08;联发科&#xff09; 2.3 QC协议 &#xff08;高通&#xff09; 2.4 VOOC闪充 &#xff08;OPPO厂商&#xff09; 2.5 SCP/FCP闪充 &#xff08;华为厂商&#xff09; 2.6 Fla…

手机技巧:如何有效清理手机的垃圾文件

大家经常碰到手机内存不够用&#xff0c;相信很多人都只会做些表面清理&#xff0c;比如删照片和视频、用手机管家清理等等&#xff0c;但这样的清理方法效果很不理想&#xff0c;基本清理不少多少垃圾文件。 当然&#xff0c;有的朋友会在手机内存空间不足的时候&#xff0c;就…

Android框架式编程之MVP架构

MVP是Google官方发布的Android开发相关的架构知识。本文要讲解的是一种最基本的MVP的实现方式&#xff0c;它使用手动的依赖注入来提供具有本地和远程数据源的存储库。异步任务处理回调。 基本的MVP示例项目地址&#xff1a;https://github.com/googlesamples/android-architec…

硬件知识:什么是扩展坞,看完你就明白了

目录 1、什么是扩展坞&#xff1f; 2、为什么会出现扩展坞&#xff1f; 3、扩展坞支持哪些接口&#xff1f; 4、笔记本PCI扩展坞的功能 5、笔记本PCI扩展坞的优点 1、什么是扩展坞&#xff1f; 扩展坞&#xff08;Docking StaTIon&#xff09;主要用来扩展笔记本电脑功能的数码…

Union和Union All到底有什么区别

union和union all的区别是,union会自动压缩多个结果集合中的重复结果&#xff0c;而union all则将所有的结果全部显示出来&#xff0c;不管是不是重复。Union&#xff1a;对两个结果集进行并集操作&#xff0c;不包括重复行&#xff0c;同时进行默认规则的排序&#xff1b; UNI…

前端工具:推荐几款UI设计师好用的设计软件

目录 1. Pixso 2. Figma 3.XD 4. Sketch 5、LR 修图神器 推荐几款UI设计师好用的设计软件&#xff0c;感兴趣的朋友可以下载试试&#xff01; 1. Pixso Pixso是一款综合设计能力超强的一个设计平台&#xff0c;它包含了原型、设计、交付、协作、资源管理一体化等众多的功能于一…

mysql新增语句

1:方式一 2:方式2