HTTP 与 HTTPS 网络传输
文章目录
- HTTP 与 HTTPS 网络传输
- HTTP(HyperText Transfer Protocol)
- HTTP 的工作原理
- HTTP 的特点
- HTTPS(HTTP Secure)
- HTTPS 的工作原理
- HTTPS 的特点
- HTTP 和 HTTPS 的对比
- HTTP 和 HTTPS 的传输过程对比
- HTTP 传输过程
- HTTPS 传输过程
- HTTPS 使用的关键技术
- 示例:HTTPS 数据传输流程
HTTP 与 HTTPS 网络传输
HTTP(HyperText Transfer Protocol)
HTTP 是一种无状态的、基于请求-响应模式的应用层协议,用于在客户端(浏览器)和服务器之间传输数据。
HTTP 的工作原理
-
请求:
- 客户端(如浏览器)向服务器发送 HTTP 请求,包含请求方法(GET、POST 等)、URL、头部信息和可选的请求体。
- 示例:
GET /index.html HTTP/1.1 Host: www.example.com
-
响应:
- 服务器处理请求并返回响应,包含状态码、响应头部和可选的响应体。
- 示例:
HTTP/1.1 200 OK Content-Type: text/html Content-Length: 1234 <html>...</html>
-
无状态性:
- HTTP 不记录请求之间的状态,除非通过 Cookie、Session 等机制扩展。
HTTP 的特点
- 优点:简单、易用、广泛支持。
- 缺点:
- 数据明文传输,缺乏加密,容易被窃听。
- 数据完整性无法保证,容易被篡改。
- 不验证通信双方身份,易受中间人攻击。
HTTPS(HTTP Secure)
HTTPS 是 HTTP 的安全版本,利用 SSL/TLS(Secure Socket Layer/Transport Layer Security)协议对数据进行加密、认证和完整性保护。
HTTPS 的工作原理
-
建立 TCP 连接:
- HTTPS 先与服务器建立一个 TCP 连接(三次握手)。
-
TLS/SSL 握手:
- 客户端与服务器通过 TLS/SSL 协议建立安全连接,包括身份认证、密钥交换和会话密钥生成。
- 主要步骤:
- 客户端发起握手:
- 客户端发送支持的加密算法列表和随机数。
- 服务器响应:
- 服务器选择加密算法并返回数字证书(包含服务器公钥和身份信息)。
- 验证证书:
- 客户端验证服务器证书的真实性(检查证书是否由可信的 CA 签发,是否过期等)。
- 密钥协商:
- 客户端生成一个随机数,用服务器的公钥加密后发送给服务器。
- 服务器用私钥解密后,与客户端协商生成对称密钥(会话密钥)。
- 加密通信开始:
- 客户端与服务器使用协商好的会话密钥加密后续数据。
- 客户端发起握手:
-
加密 HTTP 数据传输:
- 在 TLS 加密隧道内传输 HTTP 数据,请求和响应的内容都经过加密,防止窃听和篡改。
HTTPS 的特点
- 优点:
- 数据加密:所有数据传输都是加密的,防止被窃听。
- 身份验证:通过证书验证服务器身份,防止中间人攻击。
- 数据完整性:防止数据被篡改。
- 缺点:
- 配置复杂:需要购买和配置 SSL 证书。
- 性能开销:加解密过程增加了 CPU 和网络资源消耗。
HTTP 和 HTTPS 的对比
特性 | HTTP | HTTPS |
---|---|---|
安全性 | 数据明文传输,易被窃听、篡改 | 数据加密传输,确保机密性和完整性 |
身份验证 | 无身份验证,易受中间人攻击 | 使用数字证书验证服务器身份 |
加密机制 | 无加密 | 基于 SSL/TLS 加密 |
端口 | 默认使用端口 80 | 默认使用端口 443 |
性能 | 开销小 | 加解密增加了性能开销 |
HTTP 和 HTTPS 的传输过程对比
HTTP 传输过程
- 客户端向服务器发起 HTTP 请求。
- 服务器处理请求并返回 HTTP 响应。
- 数据以明文方式传输。
HTTPS 传输过程
- 客户端与服务器建立 TCP 连接。
- 通过 TLS/SSL 协议进行握手,建立加密通道。
- 客户端发起加密的 HTTP 请求。
- 服务器返回加密的 HTTP 响应。
HTTPS 使用的关键技术
-
对称加密:
- 用于加密数据传输,客户端和服务器共享同一密钥。
- 常用算法:AES、DES。
-
非对称加密:
- 用于密钥交换,使用公钥加密和私钥解密。
- 常用算法:RSA、ECDSA。
-
数字签名:
- 用于验证数据和证书的完整性。
- 服务器通过私钥对数据签名,客户端用公钥验证签名。
-
数字证书:
- 由 CA(证书颁发机构)签发,用于证明服务器的身份。
示例:HTTPS 数据传输流程
- 用户访问
https://example.com
。 - 客户端与服务器进行 TLS 握手,验证服务器证书。
- 握手成功后,双方生成对称密钥。
- 客户端用对称密钥加密请求发送给服务器。
- 服务器用对称密钥解密并处理请求,返回加密响应。
通过 HTTPS,数据传输更加安全,适合敏感信息(如密码、支付信息)保护的场景。