HTTP实用指南|青训营笔记

54 阅读2分钟

这是我参与「第四届青训营 」笔记创作活动的第3天

初始HTTP

  • 超文本传输协议
  • 应用层协议,基于TCP协议
  • 请求响应
  • 简单可扩展
  • 无状态

协议分析-报文

Method

safe(安全的):不会修改服务器的数据的方法 GET HEAD OPTIONS idempotent(幂等):同样的请求被执行一次与连续执行多次请求的效果是一样的,服务器的状态也是一样的,所有safe的方法都是idempotent的 GET HEAD OPTIONS PUT DELETE

状态码

  • 1xx 指示信息,表示请求已经接受,继续处理
  • 2xx 成功,表示请求已被成功接受、理解、接受
  • 3xx 重定向,要完成请求必须进行更进一步的操作
  • 4xx 客户端错误,请求有语法错误,或请求无法实现
  • 5xx 服务端出错误,服务器未能实现合法的请求

RESTful API

一种API设计风格

  1. 每一个URI代表一种资源
  2. 客户端和服务器之间,传递这种资源的某种表现层
  3. 客户端通过HTTP method,对服务器端资源进行操作,实现“表现层状态转化”

协议分析-发展

HTTP/2概述:更快、更稳定、更简单

  • 消息:与逻辑请求或相应消息对应的完整的一系列帧
  • 数据流:已建立的连接内的双向字节流,可承载一条或多条消息
  • 交错发送,接收方重组织
  • http/2连接都是永久的,而且仅需要每个来源一个连接
  • 流控制:阻止发送方向接受方发送大量数据的机制
  • 服务器推送 HTTPS概述
  • HTTPS:Hypertext Transfer Protocol Secure
  • 经过TSL/SSL加密
  • 对称加密:加密和解密都是使用同一个秘钥
  • 非对称加密,加密和解密需要使用两个不同的秘钥:公钥和私钥

场景分析-静态资源

方案:缓存+CDN+文件名hash

  • CDN:Content Delivery Network
  • 通过用户就近性和服务器负载的判断,CDN确保内容以一种极为高校的方式为用户的请求提供服务