http、https笔记

目录

HTTP 基本概念

状态码:

1xx 中间状态,比如post的continue

200 OK是最常⻅的成功状态码

3xx 重定向

4xx 客户端发送的报⽂有误

5xx 服务器处理时内部发⽣了错误

get和post的区别:

1、get获取数据,post改教据

2、get把请求在url上,不安全,post在http包内,安全

3、get数据最大2k,post无限制

4、get产生一个TCP包(header+data ),返回200

post产生两个TCP包(1、header返回100continue,2、data返回200 )

5.get会被缓存,post不会

6、get是幂等,post不是幂等的(get不能对数据进行修改,网络不好会多次重试)

http 常⻅字段:

Host 字段:指定服务器的域名

Content-Length 字段:本次服务器回应的数据⻓度是 1000 个字节

Connection 字段:要求服务器使⽤ TCP 持久连接,以便其他请求复⽤

Content-Type 字段:数据是什么格式

Content-Encoding 字段:数据的压缩⽅法 gzip

http的缺点:

⽆状态:Cookie 技术

明⽂传输:引⼊ SSL/TLS 层

HTTP/1.1

⻓连接:只要任意⼀端没有明确提出断开连接,则保持 TCP 连接状态

管道⽹络传输:可在同⼀个 TCP 连接⾥⾯,客户端可以发起多个请求,只要第⼀个请求发出去了,不必等其回来,就可以发第⼆个请求出去,可以减少整体的响应时间。(按照顺序)

HTTP/3

把 HTTP 下层的 TCP 协议改成了 UDP!

QUIC 有⾃⼰的⼀套机制可以保证传输的可靠性的。当某个流发⽣丢包时,只会阻塞这个流,其他流不会受到

影响。

QUIC 是⼀个在 UDP 之上的伪 TCP + TLS + HTTP/2 的多路复⽤的协议。

HTTPS

窃听⻛险:混合加密的⽅式实现信息的机密性

篡改⻛险:摘要算法的⽅式来实现完整性,它能够为数据⽣成独⼀⽆⼆的「指纹」,指纹⽤于校验数据的完整性

冒充⻛险:将服务器公钥放⼊到数字证书中,解决了冒充的⻛险

HTTPS和HTTP区别

http 明文 80端口

https

密文 443端口

过程:

1、tcp三次握手

2、ca数字证书放入非对称密钥获取会话密钥,对称密钥进行加密会话

3、http只有tcp三次握手的三个包(快),https是12个包(3+9个的ssl包)(慢)

对称加密和⾮对称加密

对称加密只使⽤⼀个密钥,运算速度快,密钥必须保密,⽆法做到安全的密钥交换。

⾮对称加密使⽤两个密钥:公钥和私钥,公钥可以任意分发⽽私钥保密,解决了密钥交换问题但速度慢

⾮对称加密

1、client、sever交换随机数

2、sever发送证书

3、client 取CA的公钥,验证数字证书,取出服务器的公钥,用服务器公钥加密随机数( pre-master key ),随后根据client、sever随机数+随机数( pre-master key )来生成会话密钥

4、sever私钥解密随机数( pre-master key ),随后根据client、sever随机数+随机数( pre-master key )来生成会话密钥

相关推荐
LinXunFeng21 小时前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
霜落长河4 天前
抛弃TCP改用UDP,HTTP3怎么了?
http
闪闪发亮的小星星5 天前
高斯光以及高斯光公式解释
笔记
程序员mine5 天前
HTTPS-TLS加密与证书完全指南(中)
网络协议·https·ssl
cqbzcsq5 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
之歆5 天前
现代 HTTP 客户端深度解析:Fetch 与 Axios
chrome·网络协议·http
阿米亚波5 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.5 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余5 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.5 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding