一、握手协议
握手协议是客户机和服务器用SSL连接通信时使用的第一个子协议,握手协议包括客户机与服务器之间的一系列消息。SSL中最复杂的协议就是握手协议。该协议允许服务器和客户机相互验证,协商加密和MAC算法以及保密密钥,用来保护在SSL记录中发送的数据。握手协议是在应用程序的数据传输之前使用的。
每个握手协议包含以下3个字段
1、Type:表示10种消息类型之一。
2、Length:表示消息长度字节数。
3、Content:与消息相关的参数。
二、握手协议的四个阶段

三、握手协议具体过程
1、建立安全能力
SSL握手的第一阶段启动逻辑连接,建立这个连接的安全能力。首先客户机向服务器发出client hello消息并等待服务器响应,随后服务器向客户机返回server hello消息,对client hello消息中的信息进行确认。
Client hello消息包括Version,Random,Session id,Cipher suite,Compression method等信息。
ClientHello:客户发送CilentHello信息,包含如下内容:
  • 客户端可以支持的SSL最高版本号
  • 一个用于生成主秘密的32字节的随机数。
  • 一个确定会话的会话ID。
  • 一个客户端可以支持的密码套件列表。(密码套件格式:每个套件都以“SSL”开头,紧跟着的是密钥交换算法。用“With”这个词把密钥交换算法、加密算法、散列算法分开,例如:SSL_DHE_RSA_WITH_DES_CBC_SHA,表示把DHE_RSA(带有RSA数字签名的暂时Diffie-HellMan)定义为密钥交换算法;把DES_CBC定义为加密算法;把SHA定义为散列算法)
  • 一个客户端可以支持的压缩算法列表。
ServerHello:服务器用ServerHello信息应答客户,包括下列内容:
  • 一个SSL版本号:取客户端支持的最高版本号和服务端支持的最高版本号中的较低者。
  • 一个用于生成主秘密的32字节的随机数。(客户端一个、服务端一个)
  • 会话ID
  • 从客户端的密码套件列表中选择的一个密码套件
  • 从客户端的压缩方法的列表中选择的压缩方法
这个阶段之后,客户端服务端知道了下列内容:
  • SSL版本
  • 密钥交换算法、散列算法和加密算法
  • 压缩方法
  • 有关密钥生成的两个随机数
2、服务器鉴别与密钥交换
服务器启动SSL握手第2阶段,是本阶段所有消息的唯一发送方,客户机是所有消息的唯一接收方。该阶段分为4步:
第一步:证书-服务器将数字证书和到根CA整个链发给客户端,使客户端能用服务器证书中的服务器公钥认证服务器。
第二步:服务器密钥交换(可选)-这里视密钥交换算法而定。
第三步:证书请求(可选)-服务端可能会要求客户自身进行验证。
第四步:服务器握手完成-第二阶段的结束,第三阶段开始的信号。
这个阶段的第一步:证书、第二步:服务器密钥交换是基于密钥交换方法的。
SSL中密钥交换算法有6种:无效(没有密钥交换)、RSA、匿名Diffie-Hellman、暂时Diffie-Hellman、固定Diffie-Hellman、Fortezza。
在SSL阶段1建立安全能力中,已经确定使哪种密钥交换算法。
如果协商过程中确定使用RSA交换密钥,那么过程如下图:
在RSA中,服务器在它的第一个信息中,发送了RSA加密/解密公钥证书。不过,因为预备主秘密是由客户端在下一个阶段生成并发送的,所以第二个信息是空的。

3、客户机鉴别与密钥交换
客户机启动SSL握手第3阶段,是本阶段所有消息的唯一发送方,服务器是所有消息的唯一接收方,该阶段分为3步。
第一步:证书(可选)-为了对服务器证明自身,客户要发送一个证书信息,这是可选的,在IIS中可以配置强制客户端证书认证。
第二步:客户机密钥交换(Pre-master-secret)-这里客户端将预备主密钥发送给服务端,注意这里会使用服务端的公钥进行加密。
第三步:证书验证(可选),对预备秘密和随机数进行签名,证明拥有第一步证书的公钥。
下面也重点介绍一下RSA方式的客户端验证和密钥交换。
这种情况,除非服务器在阶段2明确请求,否则没有证书信息。客户端密钥交换方法包括阶段2收到的由RSA公钥加密的预备主密钥。

4、完成
客户机启动SSL握手第4阶段,使服务器结束。该阶段分为4步,前2个消息来自客户机,后2个消息来自服务器。

5、密钥生成的过程
这样握手协议完成,下面看下什么是预备主密钥,主密钥是怎么生成的。
为了保证信息的完整性和机密性,SSL需要有六个加密秘密:四个密钥和两个IV。
为了信息的可信性,客户端需要一个密钥(HMAC),为了加密要有一个密钥,为了分组加密要一个IV,服务也是如此。
密钥的生成过程如下:

第一步:从预备主秘密计算主秘密

 
第二步:从主秘密计算密钥材料
第三步:从密钥材料提取加密秘密

 

  • 大小: 16.9 KB
  • 大小: 22.9 KB
  • 大小: 21.5 KB
  • 大小: 18 KB
  • 大小: 20.4 KB
  • 大小: 17.6 KB
  • 大小: 24.3 KB
  • 大小: 237.3 KB
  • 大小: 247.7 KB
  • 大小: 209.5 KB
  • 大小: 133.2 KB
  • 查看图片附件

SSL协议之握手协议相关推荐

  1. SSL连接中握手协议及握手过程

    SSL的主要目的是在两个通信应用程序之间提供私密信和可靠性.这个过程通过3个元素来完成: 1.握手协议. 握手协议负责协商被用于客户机和服务器之间会话的加密参数.当一个SSL客户机和服务器第一次开始通 ...

  2. SSL 握手协议详解

    这里重点介绍一下服务端的验证和密钥交换.这个阶段的前面的(a)证书 和(b)服务器密钥交换是基于密钥交换方法的.而在SSL中密钥交换算法有6种:无效(没有密钥交换).RSA.匿名Diffie-Hell ...

  3. SSL协议(HTTPS) 握手、工作流程详解(双向HTTPS流程)

    SSL协议的工作流程: 服务器认证阶段:1)客户端向服务器发送一个开始信息"Hello"以便开始一个新的会话连接:2)服务器根据客户的信息确定是否需要生成新的主密钥,如需要则服务器 ...

  4. 理解SSL/TLS系列 (五)握手协议

    一.概述 由于当前TLS1.2使用最为广泛,本文描述的内容都基于TLS1.2 握手是 TLS 协议中最精密复杂的部分.在这个过程中,通信双方协商连接参数,并且完成身份验证.根据使用的功能的不同,整个过 ...

  5. SSL的组成,其中握手协议和记录协议实现、密钥生成过程及其评价

    由两部分组成:SSL记录协议和SSL握手协议 1.握手协议 SSL中最复杂的协议,负责建立当前会话状态的参数,使得服务器和客户能协商一个协议版本.选择密码算法和哈希算法.压缩算法.会话ID等,并使用公 ...

  6. 和谐: OρenVΡN的UDP握手协议

    以下内容来自cnblogs博客园, 作者ksiwnhiwhs https://www.cnblogs.com/ksiwnhiwhs/p/10160580.html 3.OρenVΡN协议 3.1.Oρ ...

  7. Tor源码分析七 -- 握手协议

    本节主要讲述Tor系统中所用到的握手协议.握手协议分三层:TCP握手:TLS握手:Tor握手.其中Tor握手又分为三个层次:OR握手:链路建立:流建立. TCP的三次握手我想应该学计算机方向的朋友无人 ...

  8. TLS协议学习-第二篇-握手协议

    TLS协议学习第二篇,内容来自:https://docs.microsoft.com/en-us/previous-versions/windows/it-pro/windows-server-200 ...

  9. 物联网基础之了解CCP协议,COAP协议,MTQQ协议等

    首先介绍下背景.最近开始研究物联网的套件.公司选中了阿里物联网套件,所以博主就开始投入到漫长的开发文档中.由于博主并非嵌入式开发者,所以一些名字没有听过,这对文档的阅读造成了不少的困扰,所以在此记录一 ...

最新文章

  1. R语言ggplot2可视化:ggplot2可视化直方图(histogram)并在直方图的顶部外侧(top upper)或者直方图内部添加数值标签
  2. 聚焦五大领域:浙江大学发布《重大领域交叉前沿方向2021》报告
  3. Spring-AOP 自动创建代理
  4. 经验之谈:Linux运维工程师所需技能
  5. 1.gloox开发环境搭建
  6. 前端开发书籍推荐与学习路线
  7. php mysql插入多个列_php mysql插入多条记录
  8. android小程序:计算圆面积
  9. 除去google工具栏启动的GoogleToolbarNotifier.exe进程
  10. php redis 挂掉,redis中的宕机什么意思
  11. MarkdownPad2 解决“HTML渲染错误”
  12. Dubbox框架简介
  13. Hash Table
  14. 六个基础措施可确保企业数据安全
  15. cnckadv16安装教程(含详细安装方法)
  16. 自己设计系统之间的通信协议
  17. L2TP的windows客户端连接
  18. 孩子感冒了该吃什么药?说给程序员朋友的话
  19. 计算机专业申请书怎么写,计算机转专业申请书范文
  20. 基于android的课程表签到考试提醒app

热门文章

  1. vue rem插件与cube ui组件样式冲突
  2. 三年级信息技术用计算机打字教案,三年级上信息技术英文打字教案.pdf
  3. 基于STM32 STC15和SU-03T语音模块的智能语音垃圾桶设计
  4. 基于TM的遥感数据的叶面积指数估算解决方案
  5. 磁带和黑胶模拟器插件-Initial Audio Analog Pro LoFi v1.0.0 WiN-MAC
  6. poj 1067 石子游戏
  7. Python_代码风格_合理分解代码,提高代码可读性
  8. 数字图像处理知识点复习(上)
  9. python求时间序列的极值点
  10. P3243 [HNOI2015]菜肴制作 (拓扑排序)