【计算机网络】HTTPS协议

一、HTTPS前置概念

1.加密的相关概念

加密:将明文通过密钥变成密文

解密:将密文通过密钥变成明文

2.常见的加密方式

(1)对称加密

加密和解密所用的密钥是相同的;并且加密速度快

(2)非对称加密

非对称加密要用到两个密钥:一个叫做"公钥",一个叫做 "私钥"

通过公钥对明文加密, 变成密文;通过私钥对密文解密, 变成明文

通过私钥对明文加密, 变成密文;通过公钥对密文解密, 变成明文

非对称加密最大的问题就是运算速度非常慢

3.数据摘要(数据指纹)

数据摘要的用处:对比两个文件是否是同一个文件(进行数据对比)

4.数据签名

5.HTTPS概念

HTTPS 也是一个应用层协议,是在 HTTP 协议的基础上引入了一个加密层

二、四种有问题的方案

1.只使用对称加密

此方案无法让双方都知道密钥,所以在进行正常加密通信前要先解决如何让双方得到密钥的问题

2.一方使用非对称加密

只能保证 Client->Server 的数据安全,不能保证 Server->Client 的数据安全

3.双方使用非对称加密

确实保证了Client->Server 和 Server->Client 的数据安全,但是都用非对称加密运算速度太慢

并且这种方案还有一个隐藏的问题!(中间人把公钥调包了 -- 中间人攻击)

4.非对称加密+对称加密

利用非对称加密传递客户端的私钥C',实际通信用对称加密,这种方案解决了速度慢的问题

但是这种方案还是有一个和上面一样的隐藏问题!(中间人把公钥调包了 -- 中间人攻击)

5.中间人攻击

所以在正常的加密数据通信之前,首先要解决公钥如何被对方安全收到的问题 -- 引入CA认证

三、HTTPS的真正方案

1.CA认证

服务端在使用HTTPS前,需要向CA机构申领一份数字证书,证书可以证明服务端公钥的权威性

(1)整体流程

(2)签发证书

因为我们使用CA的私钥形成数据签名,所以,只有CA能形成可信任的证书

(3)验证证书

浏览器(客户端)验证证书的流程如图

目前,中间人没有办法进行任何局部的替换,无论是明文,还是签名!

明文不能被替换:对明文做摘要,如果被篡改就和证书上的摘要对不上了

签名不能被替换:签名只能由CA公钥解密,如果被篡改就解不开了

2.HTTPS的方案

HTTPS采用的方案是:证书认证+非对称加密+对称加密

相关推荐
心.c几秒前
《从零开始:打造“核桃苑”新中式风格小程序UI —— 设计思路与代码实现》
开发语言·前端·javascript·ui
小龙报1 分钟前
【C语言初阶】动态内存分配实战指南:C 语言 4 大函数使用 + 经典笔试题 + 柔性数组优势与内存区域
android·c语言·开发语言·数据结构·c++·算法·visual studio
倔强菜鸟1 分钟前
2025.11.21-GO语言入门(一)
开发语言·后端·golang
白露与泡影3 分钟前
从 JDK 8 到 JDK 18,Java 垃圾回收的十次进化
java·开发语言·测试工具
dragoooon343 分钟前
[Linux网络基础——Lesson10.「数据链路层 & ARP 具体过程 & ARP 欺骗」]
linux·网络·网络协议
一晌小贪欢3 分钟前
Streamlit应用如何部署到 Streamlit Community Cloud(保姆级教程)
开发语言·阿里云·部署·部署上线·streamlit应用·streamlit部署
小龙报5 分钟前
【算法通关指南:算法基础篇(三)】一维差分专题:1.【模板】差分 2.海底高铁
android·c语言·数据结构·c++·算法·leetcode·visual studio
xing.yu.CTF5 分钟前
ATT&CK实战系列--蓝队防御(三)
网络·安全·web安全·横向移动·内网对抗
Dovis(誓平步青云)5 分钟前
《Linux 网络实战手册:从 TCP/IP 协议栈到 UDP网络通信》
linux·网络·tcp/ip
国科安芯7 分钟前
AS32A601型MCU芯片flash模块的擦除和编程
java·linux·前端·单片机·嵌入式硬件·fpga开发·安全性测试