HTTP
HTTP 简介
- Hyper Text Transfer Protocol
- 应用层协议,基于TCP协议
- 分为 请求 和 响应
- 简单可扩展
- 无状态
data:image/s3,"s3://crabby-images/287e8/287e846de9565f51f536c2998ddb101c9c1346b1" alt="image.png"
协议发展
data:image/s3,"s3://crabby-images/8bcad/8bcadad8e9c2ce8db08c02382ef71ff8a50577d1" alt="image.png"
HTTP/0.9 单行协议
- 请求只有 GET/mypage.html
- 响应只有HTML文档
HTTP/1.0 构建可扩展性
HTTP/1.1 标准化协议
HTTP/2 更优异的表现
HTTP/3 草案中
协议分析–报文
Method
Safe(安全的): 不会修改服务器的数据的方法即认为是安全的:GET HEAD OPTIONS Idempotent(幂等):同样的请求被执行一次与连续执行多次效果是一样的,服务器的状态也是一样的,所有的safe都是Idempotent的 GET HEAD OPTIONS PUT DELETE data:image/s3,"s3://crabby-images/cf2b9/cf2b905e11c10220646a7187a7d8e0c42e67bfc2" alt="image.png"
状态码
data:image/s3,"s3://crabby-images/c34e0/c34e02abe34f748b0d59aa7c00734798bb0d3813" alt="image.png"
常见请求头
data:image/s3,"s3://crabby-images/8e1df/8e1dfb7e62dbe12e8a6d6eb3fbab3d962c85b21d" alt="image.png"
常见响应头
data:image/s3,"s3://crabby-images/c0d1b/c0d1be746bc675efaa2f94e2f4cb75ba35398ee9" alt="image.png"
缓存
缓存分为强缓存 和协商缓存两种
强缓存相关Header
- Expires时间戳,到期时间
- Cache-Control
- 可缓存性
- no-cache:协商缓存验证
- no-store:不使用任何缓存
- 到期
- max-age:单位是秒,存储的最大周期,相对于请求的时间
- 重新验证,重新加载
- must-revalidate:一旦资源过期,在成功向原始服务器验证之前,不能使用
协商缓存
- Etag/if-None-Match :资源的特定版本的标识符,类似于指纹
- Last-Modified/if-Modified-Since:最后修改时间
缓存相关逻辑图 data:image/s3,"s3://crabby-images/3deb8/3deb8b789d101f6bfda45cabdd2df7887f3e7c10" alt="image.png"
cookie
data:image/s3,"s3://crabby-images/dd4f7/dd4f79303d93f2444610d8c686bea67806f58b95" alt="image.png"
HTTP/2概述:更快、更稳定、更简单
HTTP/2 中使用帧进行通信 帧(frame):HTTP/2通信的最小单位,每个帧都包含帧头,至少也会标识出当前帧所属的数据流 消息:与逻辑请求或响应消息对应的完整的一些列帧 数据流 :HTTP/2在已建立的连接内双向字节流,可以承载一条或多条消息。、 传输过程中,帧是交错发送,接收方根据帧的帧头等信息重新组织起来即可
data:image/s3,"s3://crabby-images/d882d/d882d6d621836c8a4cd8d19c354607da618d4036" alt="image.png"
HTTP/2相关优点 在HTTP/1.x 中每次都是传输的如图中一个纯文本编码的message进行传输,在HTTP/2 中会将这个message划分为若干个帧 ,采用二进制编码的形式进行传输,同时还有一些压缩算法,是传输效率更高。
data:image/s3,"s3://crabby-images/b7c6c/b7c6cb228658d3b17a19c12b604d0a09d4106dad" alt="image.png"
其他特性 HTTP/2建立的连接都是永久的,而且仅需要每个来源一个连接 流控制:可以阻止或拒绝发送方向接收方发送大量数据的极致 服务器推送,服务器可以主动提前推送一些数据(例如一些静态资源)给用户方,来到达效率
data:image/s3,"s3://crabby-images/c1ab2/c1ab202eeb4438ce48a09565fa6880ed09083090" alt="image.png"
HTTPS概述
在HTTP的基础上经过TSL/SSL加密传输
data:image/s3,"s3://crabby-images/6b84f/6b84f4155e30f704ada997154b971bfdad510ef3" alt="image.png"
登录常见的方案
Session + cookie
data:image/s3,"s3://crabby-images/17ee3/17ee3a2d69712e47cd16245fd0b981be2984a3c1" alt="image.png"
JWT(JSON WEB TAKEN)
data:image/s3,"s3://crabby-images/69ece/69ece47f401cec3888177811d1b274a74da28e5d" alt="image.png"
SSO: 单点登录(Single Sign On)
data:image/s3,"s3://crabby-images/44d36/44d36730233d26e7a7fdcc54e8ab259d3da254ed" alt="image.png"
跨域解决方案
- CORS 设置相关跨域的响应头来解决跨域
- 代理服务器
- 同源策略是服务器对于浏览器的安全策略,不是对HTTP的,服务器之间没有同源策略
- 部署一台和当前浏览器域名相同的服务器,然后浏览器通过发送给代理服务器来转发请求给服务器
data:image/s3,"s3://crabby-images/0461c/0461c21c453b8f34eba218ad05cbc5af09fc91a8" alt="image.png"
用户体验优化
从网络优化方面出发
data:image/s3,"s3://crabby-images/3437a/3437a5f485bd1e5fbc5beb3ab0e7e72dce045838" alt="image.png"
- 静态资源方案: 缓存 + CDN + 文件名hash
- CDN :Content Deliverty Network
- 通过用户就就近性和服务器负载的判断,CDN确保内容以一种极为高效的方式为用户的请求提供服务
data:image/s3,"s3://crabby-images/8c4d0/8c4d0dac3e8fe5921999de3e729948d0576278d2" alt="image.png"
从稳定性出发
- 重试是保证稳定的有效手段,但要防止加剧恶劣情况
- 缓存合理使用作为最后一道防线
data:image/s3,"s3://crabby-images/80824/80824e0bc55eb8461ea69a77b44639c3dce4b0b2" alt="image.png"
WebSocket
- 浏览器与服务器进行双工通讯的网络技术
- 典型场景:实时性要求高,例如聊天室
- URL 使用 ws:// 或 wss:// 等开头
HTTP 与 WebSocket对比图
data:image/s3,"s3://crabby-images/554c7/554c7f27197c3f0bf45248e290a58ccffb0288b5" alt="image.png"
|