HTTPS 与 HTTP 的区别在哪?

ops/2025/3/1 6:49:34/
http://www.w3.org/2000/svg" style="display: none;">

HTTP与HTTPS作为互联网数据传输的核心协议,其通信机制与安全特性深刻影响着现代网络应用的可靠性与用户体验。本文将解析两者的通信流程、安全机制及核心差异。

一、HTTP的通信机制

先来看看HTTP是什么吧。

HTTP基于TCP/IP协议栈,采用经典客户端-服务器模型:

  1. TCP连接建立
    通过三次握手创建可靠传输通道(源IP:端口 ↔ 目标IP:端口),默认端口80。
  2. 请求-响应交互
    浏览器发起到服务器的 TCP 连接。
GET /index.html HTTP/1.1
Host: www.baidu.com
  1. 服务器处理与响应
    服务器接收来自浏览器的 TCP 连接。
HTTP/1.1 200 OK
Content-Type: text/html
Content-Length: 1234
<html>...</html>
  1. 交换信息
    浏览器(HTTP 客户端)与 Web 服务器(HTTP 服务器)交换 HTTP 消息。

  2. 连接终止
    完成传输后通过四次挥手断开连接,关闭 TCP 连接。

二、HTTPS的进化

HTTPS在HTTP与TCP层之间插入SSL/TLS加密层,通过三重防护机制应对安全威胁:

安全威胁防护机制实现方式
数据窃听AES-256等对称加密会话密钥动态协商
数据篡改SHA-256摘要算法数字签名验证数据完整性
身份伪造X.509数字证书体系CA机构签发服务器身份证书

那么,SSL 和 TLS 的区别是什么呢?

总的来说,SSL 和 TLS 没有太大的区别。

SSL 指安全套接字协议(Secure Sockets Layer),首次发布与 1996 年。SSL 的首次发布其实已经是他的 3.0 版本,SSL 1.0 从未面世,SSL 2.0 则具有较大的缺陷(DROWN 缺陷——Decrypting RSA with Obsolete and Weakened eNcryption)。很快,在 1999 年,SSL 3.0 进一步升级,新版本被命名为 TLS 1.0。因此,TLS 是基于 SSL 之上的,但由于习惯叫法,通常把 HTTPS 中的核心加密协议混称为 SSL/TLS。

HTTPS握手流程

  1. Client Hello:客户端发送支持的加密套件+随机数
  2. Server Hello:服务器选择加密套件+证书+随机数
  3. 密钥交换:ECDHE算法生成预主密钥
  4. 会话密钥:通过HKDF算法生成加密密钥
  5. 加密通信:应用层数据使用对称加密传输

如下图所示,以TLS层为例。

https://i-blog.csdnimg.cn/direct/0238f32780934f0ab0fd625dd6757b2d.jpeg#pic_center" alt="在这里插入图片描述" />

三、HTTP与HTTPS的不同

在协议层看看它们有什么不同。

对比维度HTTPHTTPS
传输加密明文传输SSL/TLS加密传输
端口号80443
证书要求无需证书需CA签发数字证书
响应速度RTT 3次RTT 5-7次(支持会话恢复)
头部结构无加密标识包含加密协议版本等安全参数
资源消耗增加15-20% CPU负载

四、HTTPS安全机制解析

  1. 混合加密体系
    结合非对称加密(RSA/ECC)的安全密钥交换与对称加密(AES)的高效数据加密,兼顾安全与性能。
  2. 证书链验证
    通过根证书→中间证书→服务器证书的信任链验证,防止中间人攻击。OCSP协议实时检查证书吊销状态。
  3. HSTS策略
    强制浏览器使用HTTPS连接,防范SSL剥离攻击。

五、总结

  • 端口号:HTTP 默认是 80,HTTPS 默认是 443。
  • URL 前缀:HTTP 的 URL 前缀是 http://,HTTPS 的 URL 前缀是 https://
  • 安全性和资源消耗:HTTP协议基于TCP协议构建,其传输的数据均为明文形式,且通信双方无法验证彼此身份。而HTTPS作为HTTP的安全演进版本,其通信架构分为两层:底层通过SSL/TLS协议与TCP建立安全通道,上层则承载经过加密处理的HTTP通信。该加密体系采用混合加密机制,即使用服务器数字证书中的公钥对对称会话密钥进行非对称加密传输,实际数据传输阶段则采用高效对称加密算法。相较于HTTP,HTTPS通过双重加密机制显著提升了安全性,但同时也因加解密运算增加了服务器的计算负载。

http://www.ppmy.cn/ops/162165.html

相关文章

Grok3使用体验与模型版本对比分析

文章目录 Grok的功能DeepSearch思考功能绘画功能Grok 3的独特功能 Grok 3的版本和特点与其他AI模型的比较 最新新闻&#xff1a;Grok3被誉为“地球上最聪明的AI” 最近&#xff0c;xAI公司正式发布了Grok3&#xff0c;并宣称其在多项基准测试中展现了惊艳的表现。据官方消息&am…

基于蒙特卡罗方法构建机器人全工作空间

蒙特卡罗方法简介 蒙特卡罗方法&#xff08;Monte Carlo Method&#xff09;是一种通过随机采样来解决数学问题的数值计算方法。它广泛应用于各种领域&#xff0c;包括物理学、金融、工程和计算机科学。在机械臂的运动学和控制中&#xff0c;蒙特卡罗方法可以用于路径规划、逆…

嵌入式仿真实验教学平台替换Proteus,嵌入式教学创新的新选择

近年来&#xff0c;随着物联网、人工智能等技术的快速发展&#xff0c;嵌入式系统教学对实践性和创新性的要求日益提高。传统仿真工具Proteus虽曾是教学领域的主流选择&#xff0c;但其局限性逐渐暴露。而嵌入式仿真实验教学平台凭借高仿真度、资源整合能力以及虚实结合的教学模…

openfoam中的toposet

1openfoam中的toposet 在 OpenFOAM 中&#xff0c;toposet是一个用于操作网格的集合定义和操作的工具。以下是关于toposet的一些关键信息&#xff1a; 1.1基本概念&#xff1a; toposet的含义是拓扑集合&#xff08;topology set&#xff09;。其作用是将一些点、面或者体网…

经典算法 最多约数问题

最多约数问题 正整数x的约数是能整除x的正整数。正整数x 的约数个数记为div(x)。例如&#xff0c;1&#xff0c;2&#xff0c;5&#xff0c;10 都是正整数10 的约数&#xff0c;则div(10)4。设a 和b 是2 个正整数&#xff0c;a≤b&#xff0c;找出a和b之间约数个数最多的数x的…

ShenNiusModularity项目源码学习(15:ShenNius.Admin.API项目分析)

ShenNius.Admin.Mvc项目是MVC模式的入口&#xff0c;ShenNius.Admin.Hosting项目是前后端分离模式的后台服务入口&#xff0c;这两个项目都依赖ShenNius.Admin.API项目&#xff0c;前者使用ShenniusAdminApiModule类注册服务及配置管道&#xff0c;而后者的webapi实现都在ShenN…

ubuntu22.04安装docker engine

在Ubuntu 22.04上安装Docker Engine可以通过以下步骤完成&#xff1a; 更新系统包索引&#xff1a; sudo apt update安装必要的依赖包&#xff1a; 这些包允许apt通过HTTPS使用仓库。 sudo apt install -y apt-transport-https ca-certificates curl software-properties-commo…

基于反激电路的电池充放电均衡控制

基于反激电路的电池充放电均衡控制是一种高效的能量转移型主动均衡方法&#xff0c;适用于锂离子电池组等串联电池组的管理。以下从原理、拓扑结构、控制策略和设计要点进行详细分析&#xff1a; 一、基本原理 反激电路&#xff08;Flyback Converter&#xff09;是一种隔离型…