一、握手协议
握手协议是客户机和服务器用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,服务也是如此。
密钥的生成过程如下:
第一步:从预备主秘密计算主秘密
第二步:从主秘密计算密钥材料
第三步:从密钥材料提取加密秘密
相关推荐
SSL 握手协议是 SSL 协议的核心组件之一,它负责客户端和服务器之间的身份认证和加密通信。在 SSL 握手协议中,客户端和服务器之间进行了多次交互,以确保身份认证和加密通信的安全性。 SSL 握手协议的主要过程包括...
* 客户端支持的SSL协议版本号(ProtocolVersion) * 客户端生成的随机数(Random) * 客户端支持的加密算法套件(CipherSuite) * 客户端支持的数据压缩算法(CompressionMethod) 客户端使用以下数据结构来表示...
SSL协议由握手协议、记录协议、密码套件、证书和变更密码规格等组成,确保了数据的完整性和机密性。 **二、Java SSL包使用** 在Java中,`javax.net.ssl`包提供了实现SSL通信的核心类和接口,如`SSLSocketFactory`、...
握手协议确保在实际数据传输前完成这些准备工作,从而保证应用协议数据的安全性。 #### 四、SSL协议的应用 - **Web安全**:最典型的应用是在Web浏览器与服务器之间建立安全连接,保护用户的隐私信息,如登录凭据、...
本文将深入解析SSL协议的各个方面,包括其概述、记录层协议和握手协议,并对SSL协议的安全性进行详细分析。 一、SSL协议概述 SSL协议最初由Netscape Communications Corporation开发,现在已被TLS(Transport Layer...
### SSL协议与SET协议分析 #### 一、SSL协议详解 ##### 1.1 SSL协议概述 SSL(Secure Socket Layer)安全套接层协议是由Netscape公司在1994年设计并推出的加密协议,旨在为互联网上的数据传输提供安全保护。SSL...
综上所述,SSL协议是保障网络安全的重要技术之一。它不仅能够保护数据的隐私性和完整性,还能够验证通信双方的身份,有效防止中间人攻击等安全威胁。随着技术的进步和安全需求的不断提高,SSL/TLS协议将继续发挥其...
在Java中,JSSE(Java Secure Socket Extension)提供了实现SSL协议的框架。开发者可以利用JSSE提供的API来处理SSL连接的创建和管理,包括自定义SSL上下文、信任管理器和密钥管理器等。例如,将USB Key融入JSSE,...
2. 改进握手协议:对SSL握手协议进行扩展,增加信任协商的消息类型和交互步骤。在握手阶段,除了现有的Client Hello、Server Hello等消息之外,还需要设计新的消息类型用于传输信任协商的相关信息。 3. 引入信任...
SSL协议的工作流程包括三个主要部分:握手协议、记录协议和警报协议。握手协议负责初始化安全连接,包括交换证书、协商加密算法和建立会话密钥。记录协议则负责将应用层的数据分割成块,进行加密和MAC(Message ...
TLS/SSL 协议是当前网络安全领域中最重要的协议之一,对互联网的安全传输起着至关重要的作用。在本文档中,我们将对 TLS/SSL 协议进行详细的分析和解析,旨在帮助初学者和对 SSL、TLS 感兴趣的人更好地理解这个协议...
SSL通过建立一个加密通道来实现这一点,该通道基于一种称为握手协议的过程,在此过程中客户端和服务器协商加密算法、密钥等参数。本文将详细介绍SSL握手过程中的关键步骤及其背后的技术原理。 #### 二、SSL握手过程...
SSL协议位于TCP/IP协议栈之上,应用层之下,其主要功能是在TCP提供的可靠连接的基础上,提供安全通信。SSL协议主要由以下几个子协议组成: 1. **SSL记录协议**:该协议负责对高层协议数据进行分段、压缩、添加MAC...
6. **握手协议**:SSL的握手协议负责建立、修改或终止SSL连接。整个过程包括客户端发起连接请求、服务器回应、证书交换、协商加密参数、确认握手完成等步骤。 7. **记录协议**:处理数据的分块、压缩和解压,以及加...
3. **握手过程**:在数据传输开始之前,SSL协议会进行一个“握手”过程。在这个过程中,客户端和服务器协商加密算法、创建会话密钥,并验证彼此的身份。 4. **版本与扩展**:SSL最初由网景公司开发,后来演变为TLS...
### SSL协议概述与原理 ...综上所述,SSL协议作为互联网安全通信的基础之一,为保护用户数据安全做出了重要贡献。随着技术的进步,SSL协议不断演进,逐步发展成为今天的TLS协议,持续为互联网安全保驾护航。
SSL协议简介、握手过程、工作原理、及其面临的安全问题和安全威胁