HTTP实用指南 | 青训营笔记

85 阅读2分钟

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

前言

想必HTTP已经是大家在互联网上的熟客了,但你了解它吗?如果不了解,那就跟着我的这篇笔记一起学习吧~

HTTP是什么?

HTTP是Hyper Text Transfer Protocol(超文本传输协议)的缩写,是基于TCP协议的一个简单可扩展并且无状态的应用层协议,每个HTTP请求都会分成请求和响应两部分

image.png

协议分析

发展过程

image.png 1.1协议是目前为止使用时间最久、也是公认的标准化的一个版本,直到今天仍有一些厂商在使用此版本

协议结构(以1.1为例)

image.png

Method取值

image.png

某一些请求的特点

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

状态码

  • 1开头:指示信息,表示请求已接收,继续处理。
  • 2开头:成功,表示请求已被成功接收、理解、接收。例如:200
  • 3开头:重定向,要完成请求必须进行更进一步的操作。例如:301、302
  • 4开头:客户端错误,请求有语法错误或请求无法实现。例如:401、404
  • 5开头:服务器错误,服务器未能实现合法的请求。例如:504

RESTful API

一种API设计风格

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

常用请求头

image.png

常用响应头

image.png

HTTP/2概述

HyperText Transfer Protocol Secure的缩写,经过TSL/SSL加密,有更快、更稳定、更简单的特性

重要概念

  1. 帧:HTTP/2通信的最小单位,每个帧都包含帧头,至少也会标识出当前帧所属的数据流
  2. 消息:与逻辑请求或响应消息对应的完整一系列帧
  3. 数据流:已建立的连接内的双向字节流,可以承载一条或多条消息
  4. 流控制:阻止发送方向接收方发送大量数据的机制
  5. 对称加密:加密和解密都是使用同一个密钥
  6. 非堆成加密:加密和解密需要使用两个不同的密钥:公钥(public key)和私钥(private key)