0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

SSH端口号是什么?SSH是如何工作的?

jf_uPRfTJDa 来源:5G通信 2023-11-10 10:06 次阅读

SSH(Secure Shell,安全外壳)是一种网络安全协议,通过加密和认证机制实现安全的访问和文件传输等业务。传统远程登录或文件传输方式,例如Telnet、FTP,使用明文传输数据,存在很多的安全隐患。随着人们对网络安全的重视,这些方式已经慢慢不被接受。SSH协议通过对网络数据进行加密和验证,在不安全的网络环境中提供了安全的登录和其他安全网络服务。作为Telnet和其他不安全远程shell协议的安全替代方案,目前SSH协议已经被全世界广泛使用,大多数设备都支持SSH功能。

目录

SSH端口号是什么?

SSH是如何工作的?

使用PuTTY和OpenSSHSSH密钥

SSH端口号是什么?

当SSH应用于STelnet,SFTP以及SCP时,使用的默认SSH端口都是22。当SSH应用于NETCONF时,可以指定SSH端口是22或者830。SSH端口支持修改,更改后当前所有的连接都会断开,SSH服务器开始侦听新的端口。

SSH是如何工作的?

SSH由服务器和客户端组成,在整个通信过程中,为建立安全的SSH通道,会经历如下几个阶段:

连接建立

SSH服务器在指定的端口侦听客户端的连接请求,在客户端向服务器发起连接请求后,双方建立一个TCP连接。

版本协商

SSH协议目前存在SSH1.X(SSH2.0之前的版本)和SSH2.0版本。SSH2.0协议相比SSH1.X协议来说,在结构上做了扩展,可以支持更多的认证方法和密钥交换方法,同时提高了服务能力。SSH服务器和客户端通过协商确定最终使用的SSH版本号。

算法协商

SSH支持多种加密算法,双方根据各自支持的算法,协商出最终用于产生会话密钥的密钥交换算法、用于数据信息加密的加密算法、用于进行数字签名和认证的公钥算法以及用于数据完整性保护的HMAC算法。

密钥交换

服务器和客户端通过密钥交换算法,动态生成共享的会话密钥和会话ID,建立加密通道。会话密钥主要用于后续数据传输的加密,会话ID用于在认证过程中标识该SSH连接。

用户认证

SSH客户端向服务器端发起认证请求,服务器端对客户端进行认证。SSH支持以下几种认证方式:

密码(password)认证:客户端通过用户名和密码的方式进行认证,将加密后的用户名和密码发送给服务器,服务器解密后与本地保存的用户名和密码进行对比,并向客户端返回认证成功或失败的消息。

密钥(publickey)认证:客户端通过用户名,公钥以及公钥算法等信息来与服务器进行认证。

password-publickey认证:指用户需要同时满足密码认证和密钥认证才能登录。

all认证:只要满足密码认证和密钥认证其中一种即可。

会话请求

认证通过后,SSH客户端向服务器端发送会话请求,请求服务器提供某种类型的服务,即请求与服务器建立相应的会话。

会话交互

会话建立后,SSH服务器端和客户端在该会话上进行数据信息的交互。

使用PuTTY和OpenSSH

PuTTY是Windows上经典的免费SSH连接工具,通常用于使用SSH协议远程登录设备,最新版本可以在PuTTY官网下载

OpenSSH是SSH协议的开源实现,支持在Unix操作系统上运行,最新版本可以在OpenSSH官网下载。目前Windows10已经包含OpenSSH客户端和服务器软件,可在“设置—应用—应用与功能—可选功能”中搜索安装。

SSH密钥

对称加密和非对称加密

提高安全性的基本方式就是加密,加密算法通过密钥将明文转换为密文进行安全传输。SSH在工作过程中结合使用了对称加密和非对称加密两种类型的算法,通过事先生成的SSH密钥来保证信息传输的安全性。两种加密算法的加解密过程见下图。

64a067f4-7eee-11ee-939d-92fbcf53809c.png

对称加密算法

64b158b6-7eee-11ee-939d-92fbcf53809c.png

非对称加密算法

对称加密算法使用同一个密钥对数据进行加密和解密。SSH连接建立过程中生成的会话密钥就是对称密钥,该对称密钥是由客户端和服务器端基于共享的部分信息和各自的私有数据使用密钥交换算法分别生成的。因为对称加密算法加解密的速度很快,所以适用于传输大量数据的场景。

非对称加密的发送和接收需要使用一对关联的SSH密钥,公钥和私钥。私钥由生成的一方自己保管,公钥可以发送给任何请求通信的其他人。发送方用收到的公钥对自己的通信内容进行加密,只有接收方可以使用私钥进行解密获取通信内容。非对称加密的私钥不需要暴露在网络中,安全性大大增加,但是加解密的速度比对称密钥慢得多。

SSH连接过程中的两个阶段使用了非对称加密。一个是在密钥交换阶段,服务器和客户端都生成了自己临时的公钥和私钥,用于计算出同一个用于后续加密通信内容的会话密钥。另外一个就是在用户认证阶段,利用只有匹配的私钥可以唯一解密公钥加密的内容这一特点,通过客户端的公钥私钥对验证客户端的身份。

密钥认证

SSH用户认证最基本的两种方式是密码认证和密钥认证。密码认证是将自己的用户名和密码发送给服务器进行认证,这种方式比较简单,且每次登录都需要输入用户名和密码。密钥认证使用公钥私钥对进行身份验证,实现安全的免密登录,是一种广泛使用且推荐的登录方式。密钥认证的基本原理是服务器端使用客户端的公钥对随机内容加密,客户端使用自己的私钥解密并发送给服务器以证实自己的身份,具体的过程见下图。

64bd1746-7eee-11ee-939d-92fbcf53809c.png

SSH密钥认证登录流程

在进行SSH连接之前,SSH客户端需要先生成自己的公钥私钥对,并将自己的公钥存放在SSH服务器上。

SSH客户端发送登录请求,SSH服务器就会根据请求中的用户名等信息在本地搜索客户端的公钥,并用这个公钥加密一个随机数发送给客户端。

客户端使用自己的私钥对返回信息进行解密,并发送给服务器。

服务器验证客户端解密的信息是否正确,如果正确则认证通过。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 服务器
    +关注

    关注

    12

    文章

    8116

    浏览量

    82511
  • 网络安全
    +关注

    关注

    9

    文章

    2945

    浏览量

    58678
  • SSH
    SSH
    +关注

    关注

    0

    文章

    177

    浏览量

    16075
  • SSH协议
    +关注

    关注

    0

    文章

    4

    浏览量

    1586

原文标题:一口气把 SSH 原理搞懂了

文章出处:【微信号:5G通信,微信公众号:5G通信】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    如何通过已占用的端口号找到占用端口的容器?

    在一个已启动了N多个容器Linux操作系统的宿主机上,新启动一个映射到宿主机端口号为portM的容器时,提示端口被占用。
    的头像 发表于 07-26 08:45 6832次阅读
    如何通过已占用的<b class='flag-5'>端口号</b>找到占用<b class='flag-5'>端口</b>的容器?

    理解网络端口号

    之前一直对网络端口号不是很理解,今天在网上查找问题时找到一篇关于端口号的解释。看了之后对网络号有点理解了。发出来免得以后忘了。嘻嘻!以下是我摘录的文字: 首先了解一下TCP/IP协议中的端口指的是
    发表于 02-06 10:16

    请问zigbee的端口号和短地址有什么区别?端口号如何知道?

    本帖最后由 一只耳朵怪 于 2018-6-1 14:51 编辑 zigbee的端口号和短地址有啥子区别,短地址可以通过这个NLME_GetShortAddr()取得,端口号如何知道?
    发表于 06-01 05:57

    怎样去解决复位端口号增长的问题

    如何清除Win7中被占用的COM口 串口,复位端口号?长期使用电脑,端口号会越用越多,如何解决此问题?WIN7 系统实际测试有用:1、打开注册表编辑器:开始—运行:regedit2、进入
    发表于 01-13 06:36

    嵌入式学习——ElfBoard ELF1板卡 修改ssh默认端口号的方法

    root@ELF1:~# /etc/init.d/dropbear restart 3.ssh登录 ELF 1开发板通过网线和电脑连接,打开putty,输入网口ip,端口号修改成自己设置的,open打开串口,输入用户名即可登录。
    发表于 10-26 13:26

    i.MX6ULL——ElfBoard ELF1板卡 修改ssh默认端口号的方法

    root@ELF1:~# /etc/init.d/dropbear restart 3.ssh登录 ELF 1开发板通过网线和电脑连接,打开putty,输入网口ip,端口号修改成自己设置的,open打开串口,输入用户名即可登录。
    发表于 10-26 13:30

    SSH定义及应用

    学习完本课程,您应该能够:了解SSH定义及应用。掌握SSH和SFTP工作原理,掌握SSH和SFTP应用,掌握SSH和SFTP的配置及维护。
    发表于 04-12 17:38 12次下载

    工业交换机端口号具有哪些结构特征

    假如按工业交换机的端口号构造来分,工业交换机大概可分成:固定不动端口号工业交换机和模块化设计工业交换机二种不一样的构造。实际上也有一种是二者兼具,那便是在出示基础固定不动端口号的基本以上再配置一定的拓展扩展槽或控制模块。下面详细
    的头像 发表于 12-10 16:15 1814次阅读

    SSH第3部分:配置SSH反向隧道以减少暴露的端口

    的 Web 服务。您还可以使用 SSH 隧道创建跳转框和网关,允许远程连接到您的网络,而无需暴露额外的网络端点或端口
    的头像 发表于 01-03 09:45 1739次阅读
    <b class='flag-5'>SSH</b>第3部分:配置<b class='flag-5'>SSH</b>反向隧道以减少暴露的<b class='flag-5'>端口</b>

    C#是如何获取电脑中的端口号

    我们经常在使用一个串口软件的时候,发现软件中的端口号并不是普通的COM1,而是带有硬件信息的。
    的头像 发表于 02-22 15:30 2902次阅读
    C#是如何获取电脑中的<b class='flag-5'>端口号</b>

    如何修改Linux系统的SSH端口

    SSH 是一种网络协议,用于与 Linux 系统进行远程安全通信。默认情况下,SSH 服务使用端口 22。
    的头像 发表于 03-20 16:46 1835次阅读

    SSH端口号是什么?SSH原理详解分析

    OpenSSH是SSH协议的开源实现,支持在Unix操作系统上运行,最新版本可以在OpenSSH官网下载。目前Windows10已经包含OpenSSH客户端和服务器软件,可在“设置—应用—应用与功能—可选功能”中搜索安装。
    发表于 10-16 16:00 2601次阅读
    <b class='flag-5'>SSH</b><b class='flag-5'>端口号</b>是什么?<b class='flag-5'>SSH</b>原理详解分析

    NAS教程丨如何通过SSH访问TNAS

    ,在Port栏输入9222或你设置的端口号,点击Open; 4、在弹出的Putty框中输入NAS用户名,按回车键; 5、输
    的头像 发表于 10-19 11:40 1055次阅读
    NAS教程丨如何通过<b class='flag-5'>SSH</b>访问TNAS

    zookeeper端口号在哪看

    Zookeeper是一个开源的分布式协调服务,它主要用于分布式系统中的配置管理、命名服务、分布式同步和分布式协调。在Zookeeper中,端口号是非常重要的一个参数,它决定了Zookeeper服务
    的头像 发表于 12-04 10:36 1511次阅读

    Ubuntu修改SSH默认端口指南

    修改SSH(Secure Shell)默认端口是一种增加系统安全性的方法,因为大多数攻击都是针对默认端口22进行的。以下是在Ubuntu系统上修改SSH默认
    的头像 发表于 12-21 17:27 461次阅读