百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

SSL/TLS 协议

nanshan 2024-11-18 15:14 10 浏览 0 评论

SSL/TLS 协议位于网络 OSI 七层模型的会话层,用来加密通信。SSL(Secure Sockets Layer,安全套接字层)是一种标准安全协议,用于在在线通信中建立Web服务器和浏览器之间的加密链接。SSL 通过互相认证、使用数字签名确保完整性、使用加密确保私密性,以实现客户端和服务器之间的安全通讯。

TLS(Transport Layer Security,传输层安全)是 IETF 在 SSL 3.0 的基础上设计的协议,它是 SSL 协议的升级版。两者差别极小,可以理解为 TLS 是 SSL 3.1。

TLS 协议结构

TLS 协议分成两层:TLS 记录协议(TLS record protocol)、TLS 握手协议(TLS handshake protocol)

TLS 握手协议负责加密以外的其他事情。握手协议分成 4 个子协议,分别是:

  • 握手协议 :负责通信双方之间协商决定密码算法和共享密钥
  • 密码规格变更协议 :负责向通信对象传达变更密码方式的信号
  • 警告协议 :负责在发生错误时将错误传给对方
  • 应用数据协议 :是将TLS承载的应用数据传达给通讯对象

TLS 记录协议负责消息的压缩、加密以及数据的认证。TLS 记录协议使用到的所有的算法等都是经过握手协议协商确认后的,以保证通讯双方是使用相同的算法。处理过程:

  • 首先,消息会被分割成多份,并用协商好的压缩算法进行压缩。
  • 其次,压缩片段会加上消息认证码以保证完整性,为了防止重放攻击还加上了片段编号。
  • 再次,压缩后的消息片段会加上消息认证码一起进行加密。加密使用 CBC 模式,初始向量是通过主密码生成。
  • 最后,加密后的报文,再加上数据类型、版本号、压缩后的长度组成的报头,就是最终的数据报文。

握手过程

  1. ClientHello(客户端 -> 服务器)
  • 客户端向服务端发送自己的信息:可用的版本号、当前时间、客户端随机数、会话ID、可用的密码套件清单、可用的压缩方式清单。
  • 可用的版本号、可用的密码套件清单、可用的压缩方式清单:因为不同的浏览器可能支持的情况不一样,所以需要发送给服务端以方便协商。
  • 当前时间:TLS不使用,但是上层的协议有可能使用。
  • 客户端随机数:后面会使用到。
  • 会话ID:客户端和服务端需要重新使用之前的连接时,会使用到此信息。
  1. ServerHello(服务器 -> 客户端)
  • 服务端向客户端发送自己的信息:使用的版本号、当前时间、服务器随机数、会话ID、使用的密码套件清单、使用的压缩方式清单
  • 使用的版本号、使用的密码套件清单、使用的压缩方式清单:这里发送的就是协商后的确定结果
  • 当前时间:TLS不使用,但是上层的协议有可能使用
  • 服务器随机数:后面会使用到
  1. Certificate(服务器 -> 客户端)
  • 发送服务器的证书,包含证书清单,客户端会对其进行验证。如果是匿名通信,则不发送该消息。
  • 如果 Certificate 不足以满足需求时,则会发送 ServerKeyExchange (服务器 -> 客户端)消息。具体的内容根据密码套件的不同而有所不同。这个不是必须的。
  • 双向认证,服务器则会发送 CertificateRquest(服务器 -> 客户端)找客户端要其证书用来验证。这个也不是必须的。
  1. ServerHelloDone(服务器 -> 客户端)
  • 通知客户端 Hello 时间结束。
  • 如果服务器要了客户端的证书,则客户端发送 Certificate(客户端 -> 服务器)将其证书发送给服务器。
  1. ClientKeyExchange(客户端 -> 服务器)
  • 这个就是最关键的一步,交换生成最终密钥的关键素材。
  • 如果是使用的 RSA,则会将经过服务器公钥加密的预备主密码随着 ClientKeyExchange 消息一起发送。
  • 如果是 Diffie-Hellman 密钥交换,则随着 ClientKeyExchange 消息一起发送的是 Diffie-Hellman 公开值。
  • 预备主密码使得服务端和客户端分别计算出相同的主密码。
  • 如果服务器向客户端发送了消息,客户端还会向服务器发送 CertificateVerify(客户端 -> 服务器)消息,这是为了向服务器证明,自己确实是真实的客户端,拥有客户端证书的私钥。为了实现这个目的,客户端会计算主密码和握手协议种传送的消息的散列值加上自己的数字签名后发送给服务器。
  1. 生成密钥
  • 根据关键的密钥素材主密码生成:对称密码的密钥、消息认证码的密钥、对称密码的CBC模式中使用的初始化向量
  1. ChangeCipherSpec(客户端 -> 服务器)和 Finished(客户端 -> 服务器)
  • ChangeCipherSpec这不是握手协议,而是密码规格变更协议。客户端告诉服务器我要换密码了。因为已经双方已经交换了密码套件信息,可以开始切换密码进行通信了。
  • Finished代表客户端已经搞定了
  1. ChangeCipherSpec(服务器 -> 客户端)Finished(服务器 -> 客户端)
  • ChangeCipherSpec服务器告诉客户端,我要开始换密码了
  • Finished代表服务器已经搞定了

相关推荐

Centos7虚拟机安装及网络配置(二)

#二、centos7的网络配置-Nat模式NAT模式也是VMware创建虚拟机的默认网络连接模式。使用NAT模式网络连接时,VMware会在主机上建立单独的专用网络,用以在主机和虚拟机之间相互通信。虚...

网络分析shell脚本(实时流量+连接统计)

介绍一个强大的分析网络的shell脚本,此脚本是从EZHTTP拆分出来的,觉得有必要单独介绍下。脚本运行效果截图:此脚本包含的功能有:1、实时监控任意网卡的流量2、统计10秒内平均流量3、统计每个端口...

Centos之Could not retrieve mirrorlist解决方案

Centos之Couldnotretrievemirrorlist解决方案:vi/etc/sysconfig/network-scripts/ifcfg-你的网卡名字修改:ONBOOT=ye...

一文掌握!VirtualBox 中 Rock9.x(Linux)网络配置全攻略

一、前言记得我有一篇文章《必看!VirtualBox中Centos7(Linux)网络配置全攻略》讲的非常明细,但是因为CentOS已经停止维护了,可能很多人都不想继续学CentOS,我也是一样,...

CentOS 6.0 设置IP地址、网关、DNS

在做任何操作之前先备份原文件,我们约定备份文件的名称为:源文件名称+bak,例如原文件名称为:centos.txt那么备份文件名称为:centos.txtbak引言:linux的网卡IP地址是存放在文...

Linux CentOS 基础操作(centos怎么操作)

简介:养成学习Linux的好习惯,第一是多查看manpage(manual)等帮助文档和利用好Tab键;第二是掌握好一些快捷键,比如ctrl+c(停止当前进程),ctrl+r(查看命令历史)...

Linux抓包王者技能!这条命令直接封神,教你精准定位网络问题

在网络故障排查和性能调优中,抓包是一项必不可少的技能。对于Linux环境下的网络工程师和运维人员来说,掌握高效抓包方法至关重要。而要说“抓包界的王炸”,那非tcpdump莫属!今天,我们不仅要介绍...

「干货」如何在 Linux 上划分VLAN?

在某些场景中,我们希望在Linux服务器(CentOS/RHEL)上的同一网卡分配来自不同VLAN的多个ip。这可以通过启用VLAN标记接口来实现,但要实现这一点,首先必须确保交换机上添加多个vl...

CentOS 8 网络配置实战教程:静态IP、路由与DNS设置

一、配置前准备1.查看当前网络信息#查看所有网络接口nmclidevicestatus#查看指定网卡信息(假设网卡名为ens192)ipaddrshowens192#查看路由...

Debian10.7修改网络配置(debian怎么配置网络)

简介:关于Debian获取IP地址的方法主要有两种,动态获取和静态设置。在配置网络之前先要知道Debian的网卡名称是什么,Debian可通过命令#ipa查看网卡名称。本文主要通过介绍Debian...

巧用SSH转发功能深入穿透内网(ssh转发udp)

ssh能够提供客户端到服务端的加密传输,当http、ftp等协议被防火墙所拦截时,可以考虑使用SSH的端口转发功能,将其它TCP端口的网络数据通过SSH连接来转发。转发方式一共有三种,分别是:动态转发...

CentOS Linux 7 的IP地址配置(centos7.4配置ip地址)

前段时间有位朋友,在一台PC机上安装了CentOSLinux7系统,因为要接入局域网,需要配置IP地址和默认网关信息。于是参照一本Linux教程上编辑网卡配置信息的方法,输入:vim/etc/s...

教你如何在 Linux 上划分VLAN(linux怎么分区详解)

在某些场景中,我们希望在Linux服务器(CentOS/RHEL)上的同一网卡分配来自不同VLAN的多个ip。这可以通过启用VLAN标记接口来实现,但要实现这一点,首先必须确保交换机上添加多个vl...

打通数据高速公路:如何在 CentOS 上使用 Thunderbolt 3 和 4

Thunderbolt3与4是现代高速外设连接的代表,带来了40Gbps的惊人带宽,支持数据、视频、音频与供电的“四合一”功能,尤其在专业视频编辑、科研计算、虚拟化扩展等领域具有巨大价值...

VMware 虚拟机 CentOS7 桥接模式静态 IP 配置全攻略

虚拟机桥接模式原理配置成桥接网络连接模式的虚拟机就当作主机所在以太网的一部分,虚拟系统和宿主机器的关系,就像连接在同一个Hub上的两台电脑,可以像主机一样可以访问以太网中的所有共享资源和网络连接,可以...

取消回复欢迎 发表评论: