HTTP 简述
HTTP
html
特点:无连接、无状态、灵活、简单快速 缺点:无状态、不安全、明文传输、队头阻塞
1. HTTP 报文组成部分
- 请求报文:由请求行、请求头、空行、请求体四部分组成
- 响应报文:由状态行、响应头、空行、响应体四部分组成
2. HTTP 请求方法(9 种)
- HTTP1.0: GET、POST、HEAD
- HTTP1.1: PUT、PATCH、DELETE、OPTIONS、TRACE、CONNECT
3. 常见 HTTP 状态码
- 1xx: 指示信息——表示请求已接收,继续处理
- 2xx: 成功——表示请求已被成功接收
- 3xx: 重定向——表示要完成请求必须进行进一步操作
- 4xx: 客户端错误——表示请求有语法错误或请求无法实现
- 5xx: 服务端错误——表示服务器未能实现合法的请求
4. 什么是持久连接/长连接
- http1.0 协议采用的是"请求-应答"模式,当使用普通模式,每个请求/应答客户与服务器都要新建一个连接,完成之后立即断开连接(http 协议为无连接的协议)
- http1.1 版本支持长连接,即请求头添加 Connection: Keep-Alive,使用 Keep-Alive 模式(又称持久连接,连接复用)建立一个 TCP 连接后使客户端到服务端的连接持续有效,可以发送/接受多个 http 请求/响应,当出现对服务器的后续请求时,Keep-Alive 功能避免了建立或者重新建立连接
5. 如何解决 HTTP 的队头阻塞问题
- 并发连接: 现在的浏览器标准中一个域名并发连接可以有 6~8 个,记住是 6~8 个,不是 6 个(Chrome6 个/Firefox8 个)
- 域名分片:
- 一个域名最多可以并发 6~8 个,那咱就多来几个域名。比如 a.baidu.com,b.baidu.com,c.baidu.com
- 而在 HTTP2.0 下,可以一瞬间加载出来很多资源,因为支持多路复用,可以在一个 TCP 连接中发送多个请求
6. HTTP 代理
- 普通代理(中间人代理)
- 隧道代理
- 代理服务器好处:突破访问限制 / 安全性更高 / 负载均衡 / 缓存代理
7. 正向代理和反向代理
- 正向代理
- 缓存
- 屏蔽某些不健康的网站
- 通过代理访问原本无法访问的网站
- 上网认证,对用户访问进行授权
- 反向代理通常用于:负载均衡、服务端缓存、流量隔离、日志、金丝雀发布
HTTPS
概念
HTTPS 是超文本传输安全协议,即 HTTP + SSL/TLS
为了保证安全,TLS 需要保证信息的:机密性、可用性、完整性、认证性、不可否认性
HTTPS 在内容传输的加密上使用的是对称加密,非对称加密只作用在证书验证阶段
HTTPS 要使客户端与服务器端的通信过程得到安全保证,必须使用的对称加密算法,但是协商对称加密算法的过程,需要使用非对称加密算法来保证安全,然而直接使用非对称加密的过程本身也不安全,会有中间人篡改公钥的可能性,所以客户端与服务器不直接使用公钥,而是使用数字证书签发机构颁发的证书来保证非对称加密过程本身的安全。这样通过这些机制协商出一个对称加密算法,就此双方使用该算法进行加密解密。从而解决了客户端与服务器端之间的通信安全问题。
对称加密 / 非对称加密 / 证书
1、对称加密 (不安全)
网络通信中,加密和解密用的是「同一个密钥」
2、非对称加密(RSA):
协商一对钥匙:一个是保密的,「私钥」;一个是公开的,「公钥」。
特点是:私钥加密后的密文,只要是公钥,都可以解密,但是公钥加密后的密文,只有私钥可以解密。私钥只有一个人有,而公钥可以发给所有的人。
私钥加密的数据只有对应的公钥才能解密; 公钥加密的数据只有对应的私钥才能解密。
缺点:RSA 算法速度有点慢
私钥?公钥怎么来的?(一对公私钥只能实现「单向」的加解密)
- 客户端 --(发信息给)--> 服务端:
- 服务端生成「公钥」和「私钥」,「公钥」发给客户端,客户端用「公钥」加密内容发给服务端,服务端用「私钥」解密。
- 「私钥」一直在服务端,被人劫持也无法解密客户端发送的内容
- 服务端 --(发信息给)--> 客户端:
- 客户端生成「公钥」和「私钥」,「公钥」发给服务端,服务端用「公钥」加密内容发给客户端,客户端用「私钥」解密。
- 「私钥」一直在客户端,被人劫持也无法解密服务端发送的内容
结论:不安全
- 拿到「公钥」一方加密数据发给握有「私钥」的一方,是安全的
- 有安全漏洞,无法确认「公钥」的真假
3、非对称加密 + 对称加密:(随机数 Bob:对称加密密钥。随机数的好处是交互的那一刻才确定加密算法)
- 第一步:生成「对称加密」的「密钥」,用「RSA」的方式传给对方
- Step 1:服务端生成「公钥」发给客户端,自己存「私钥」
- Step 2:客户端本地生成「随机数 Bob」,并用「公钥」加密「随机数 Bob」
- Step 3:服务端用「私钥」解密客户端发过来的「随机数 Bob」,并用「随机数 Bob」进行加密内容「XYZ」
- Step 4:客户端用本地「随机数 Bob」解密服务端发过来的内容,得到「XYZ」
- 第二步:用「对称加密」的「密钥」通信
4、中间人劫持:
- 「3」理论上应该是: A --真公钥 Tt--> B,B --真公钥 Tt 加密内容--> A
- 「中间人劫持」后变成:
- A --真公钥 Tt--> X --假公钥 Ff--> B,
- B --假公钥 Ff 加密内容 588--> X(假私钥解密 588,篡改成 688) --真公钥 Tt 加密内容--> A(真私钥解密后收到 688)
5、CA 证书:
- A-- 真公钥 Tt -- CA 机构用「私钥 c」加密「真公钥 Tt」-- B(用 CA 发过来的「公钥 c」解密「真公钥 Tt」
- B -- 生成随机数 Bob,真公钥 Tt 加密随机数 Bob -- A(解密得到 Bob),AB 用「随机数 Bob」对称加密来通信
- 现实中,「浏览器」和「操作系统」都会维护一个权威的第三方机构列表(包括它们的公钥)
- 不过,如果「浏览器」和「操作系统」中的「CA 证书」被篡改,依然有被中间人劫持的风险
6、数字签名 & 数字证书?
TODO...
网络相关
抓包
TODO...
HTTP2 与 HTTP1.1
- 1.1:域名分片
- 2: 多路复用
- 2: HPACK 算法 --> 静态表?
- 2: 服务端推送 / Push 推送
- HTTP2 还是基于 TCP 的
- 丢包率
- 问题: 队头阻塞
- TCP / UDP
- 都是传输层协议
- TCP 连接(3 握手/4 挥手),UDP 报文
- 重传
- HTTP 3
- HTTP 缓存
- 对称加密 / 非对称加密 / 证书
web 安全防御
- XSS
- 存储型
- 转义 / 过滤
- CSP ? 源头
- CSRF
- cookie
- token
前端错误监控
- sentry
- https://juejin.cn/post/6959356863246925832
- 采集 / 上报
- onerror
- 框架自带的错误回调: vue / react
- 上报: source-map / sendBeacon
- 入库
- 数据清洗: 同一错误重复采集的情况
- mysql / 展示
- 分析
tcp / ip
TODO...
Storing data in the browser
- Cookie
- LocalStorage
- SessionStorage
request
- XMLHttpRequest
- Axios
- fetch