我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何理解HTTPS以及SSL单向验证和双向验证

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何理解HTTPS以及SSL单向验证和双向验证

本篇文章给大家分享的是有关如何理解HTTPS以及SSL单向验证和双向验证,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

 

主要介绍HTTPS以及SSL单向验证和双向验证。

HTTPS介绍

HTTPS是一种通过计算机网络进行安全通信的传输协议,经由HTTP进行通信,利用SSL/TLS建立安全信道,加密数据包。HTTPS使用的主要目的是提供对网站服务器的身份认证,同时保护交换数据的安全性与完整性。

HTTP介绍

HTTP是超文本传输协议,是一个基于请求与响应、无状态的、应用层的协议,常基于TCP/IP协议传输数据,互联网上应用最为广泛的一种网络协议,所有的WWW文件都必须遵守这个标准。

SSL/TLS介绍

TLS在传输层对网络连接进行加密,前身是SSL协议,由网景公司1995年发布,用以保障数据在Internet上安全地进行传输,利用数据加密(Encryption)技术,确保数据在网络传输过程中不会被截取或窃听。

数据加密用到了对称加密和非对称加密,TCP协议建立传输连接时,SSL首先对对称加密的密钥使用非对称加密的公钥进行非对称加密,连接建立好之后,SSL对传输内容使用对称加密。

对称加密,速度高,可加密内容较大,用来加密会话过程中的消息。

非对称加密,加密速度较慢,但能提供更好的身份认证技术,用来加密对称加密的密钥。

OSI模型

HTTPS和HTTP协议位于应用层,SSL\TLS协议位于传输层与应用层之间,TCP协议位于传输层,IP协议位于网络层。如下图所示:

如何理解HTTPS以及SSL单向验证和双向验证

图 1 协议模型

SSL单向验证

客户端执行HTTPS请求时,需要由TCP协议建立和释放连接。这就涉及TCP协议的三次握手和四次挥手。想要了解一文读懂TCP三次握手工作原理及面试常见问题汇总和一文读懂TCP四次挥手工作原理及面试常见问题汇总的同学,请点击链接查看。

TCP连接建立好后,对于HTTP而言,服务器就可以发送数据给客户端。但是对于HTTPS,它还要运行SSL/TLS协议,SSL/TLS协议分两层,第一层是记录协议,主要用于传输数据的加密压缩;第二层是握手协议,它建立在第一层协议之上,主要用于数据传输前的双方身份认证、协商加密算法、交换密钥。

SSL单向验证流程:

如何理解HTTPS以及SSL单向验证和双向验证

图 2 SSL单向验证流程

SSL单向验证总共有四步

1) 第一步,客户端向服务器端发起Client Hello,请求内容包括:

a. 客户端支持的SSL/TLS协议版本列表;

b. 客户端支持的对称加密算法列表;

c. 客户端生成的随机数A;

2) 第二步,服务器端回应客户端Server Hello,回应内容包括:

a. 双方都支持的SSL/TLS协议版本;

b. 双方都支持的对称加密算法;

c. 服务器密钥库中的证书;

d. 服务器端生成的随机数B;

3) 第三步,客户端收到服务器端回应,客户端检查服务器端证书是否合法,验证内容如下:

a. 服务器端证书是否过期;

b. 服务器端证书是否被吊销;

c. 服务器端证书是否可信;

d. 服务器端证书域名和客户端请求域名是否一致。

验证通过后,客户端回应服务器端,回应内容包括:

a.  客户端生成一个"随机数C","随机数C"也被称为"pre-master-key",然后使用服务器端证书中的公钥加密"随机数C",将加密后的"随机数C"发送给服务器端;

4)  第四步,服务器端使用密钥库中的私钥解密加密后的"随机数C"得到"随机数C",此时客户端和服务器端都拿到了随机数A、随机数B、随机数C,双发通过这3个随机数使用相同的密钥交换算法计算得到相同的对称加密密钥,这个对称加密密钥就作为客户端和服务器端数据传输时对称加密使用的密钥。

服务器端和客户端,握手结束,之后就可以用对称加密传输数据了。

SSL双向验证

SSL单向验证过程中,客户端会验证自己访问的服务器端,服务器端对客户端不做验证。如果服务器端验证客户端,则需要开启服务器端验证,这就是双向验证。

SSL双向验证和单向验证的不同之处在于:

a. 第二步中服务器端第一次回应客户端的Server Hello消息中,会要求客户端提供客户端证书;

b. 第三步中客户端验证完服务器端证书后,回应的内容中,会增加两个信息:

a) 客户端证书;

b) 客户端证书验证消息(CertificateVerify  message):客户端将之前所有收到的和发送的消息组合起来,并用hash算法得到一个hash值,然后用客户端密钥库的私钥对这个hash进行签名,这个签名就是CertificateVerify  message;

c. 服务器端收到客户端证书后,会做如下处理:

a) 确认客户端发送的证书是有效合法的;

b) 用客户端证书中的公钥验证收到信息中的签名,以确定这个证书是客户端发出的;

服务器端和客户端,握手结束,之后就可以用对称加密传输数据了。

以上就是如何理解HTTPS以及SSL单向验证和双向验证,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何理解HTTPS以及SSL单向验证和双向验证

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何理解HTTPS以及SSL单向验证和双向验证

本篇文章给大家分享的是有关如何理解HTTPS以及SSL单向验证和双向验证,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 主要介绍HTTPS以及SSL单向验证和双向验证。HTTP
2023-06-17

C#开发中如何处理网络安全和身份验证问题及解决方法

C#开发中如何处理网络安全和身份验证问题及解决方法随着信息技术的高速发展,网络安全和身份验证成为了C#开发过程中必须要重视的问题。在这篇文章中,我们将探讨C#开发中如何处理网络安全和身份验证问题,并提供一些解决方法和具体代码示例。一、网络安
2023-10-22

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录