IT@程序员猿媛网络

【网络协议笔记】HTTP 协议整理

2019-07-09  本文已影响2人  58bc06151329

文前说明

作为码农中的一员,需要不断的学习,我工作之余将一些分析总结和学习笔记写成博客与大家一起交流,也希望采用这种方式记录自己的学习之旅。

本文仅供学习交流使用,侵权必删。
不用于商业目的,转载请注明出处。

1. 概要

2. 原理

2.1 报文格式

2.1.1 请求报文

GET / HTTP/1.1
Host: server.example.com
Connection: Upgrade, HTTP2-Settings
Upgrade: h2c
HTTP2-Settings: <base64url encoding of HTTP/2 SETTINGS payload>
请求报文通用格式

请求方法说明

方法 说明
PTIONS 返回服务器针对特定资源所支持的 HTTP 请求方法。也可以利用向 Web 服务器发送 '*' 的请求来测试服务器的功能性。
HEAD 向服务器索要与 GET 请求相一致的响应,只不过响应体将不会被返回。这一方法可以在不必传输整个响应内容的情况下,就可以获取包含在响应消息头中的元信息。
GET 向特定的资源发出请求。
POST 向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的创建和/或已有资源的修改。
PUT 向指定资源位置上传其最新内容。
DELETE 请求服务器删除 Request-URI 所标识的资源。
TRACE 回显服务器收到的请求,主要用于测试或诊断。
CONNECT HTTP/1.1 协议中预留给能够将连接改为管道方式的代理服务器。
PATCH 是对 PUT 方法的补充,用来对已知资源进行局部更新 。

2.1.2 响应报文

HTTP/1.1 200 OK
Content-Length: 243
Content-Type: text/html
响应报文通用格式

HTTP 状态码分类

分类 描述
1** 信息,服务器收到请求,需要请求者继续执行操作。
2** 成功,操作被成功接收并处理。
3** 重定向,需要进一步的操作以完成请求。
4** 客户端错误,请求包含语法错误或无法完成请求。
5** 服务器错误,服务器在处理请求的过程中发生了错误。

HTTP 状态码说明

状态码 英文名称 说明
100 Continue 继续。客户端应继续其请求。
101 Switching Protocols 切换协议。服务器根据客户端的请求切换协议。只能切换到更高级的协议,例如,切换到 HTTP 的新版本协议。
102 Processing 由 WebDAV(RFC 2518)扩展的状态码,代表处理将被继续执行。
200 OK 请求成功。一般用于 GET 与 POST 请求。
201 Created 已创建。成功请求并创建了新的资源。
202 Accepted 已接受。已经接受请求,但未处理完成。
203 Non-Authoritative Information 非授权信息。请求成功。但返回的 meta 信息不在原始的服务器,而是一个副本。
204 No Content 无内容。服务器成功处理,但未返回内容。在未更新网页的情况下,可确保浏览器继续显示当前文档。
205 Reset Content 重置内容。服务器处理成功,用户终端(例如:浏览器)应重置文档视图。可通过此返回码清除浏览器的表单域。
206 Partial Content 部分内容。服务器成功处理了部分 GET 请求。
207 Multi-Status 由 WebDAV(RFC 2518)扩展的状态码,代表之后的消息体将是一个 XML 消息,并且可能依照之前子请求数量的不同,包含一系列独立的响应代码。
300 Multiple Choices 多种选择。请求的资源可包括多个位置,相应可返回一个资源特征与地址的列表用于用户终端(例如:浏览器)选择。
301 Moved Permanently 永久移动。请求的资源已被永久的移动到新 URI,返回信息会包括新的 URI,浏览器会自动定向到新 URI。今后任何新的请求都应使用新的 URI 代替。对于某些使用 HTTP/1.0 协议的浏览器,当它们发送的 POST 请求得到了一个 301 响应的话,接下来的重定向请求将会变成 GET 方式。
302 Found 临时移动。与 301 类似。但资源只是临时被移动。客户端应继续使用原有 URI。
303 See Other 查看其它地址。与 301 类似。使用 GET 和 POST 请求查看。
304 Not Modified 未修改。所请求的资源未修改,服务器返回此状态码时,不会返回任何资源。客户端通常会缓存访问过的资源,通过提供一个头信息指出客户端希望只返回在指定日期之后修改的资源。
305 Use Proxy 使用代理。所请求的资源必须通过代理访问。
306 Unused 已经被废弃的 HTTP 状态码。
307 Temporary Redirect 临时重定向。与 302 类似。使用 GET 请求重定向。
400 Bad Request 客户端请求的语法错误,服务器无法理解。
401 Unauthorized 请求要求用户的身份认证。
402 Payment Required 保留,将来使用。
403 Forbidden 服务器理解请求客户端的请求,但是拒绝执行此请求。
404 Not Found 服务器无法根据客户端的请求找到资源(网页)。通过此代码,网站设计人员可设置 " 您所请求的资源无法找到 " 的个性页面。
405 Method Not Allowed 客户端请求中的方法被禁止。
406 Not Acceptable 服务器无法根据客户端请求的内容特性完成请求。
407 Proxy Authentication Required 请求要求代理的身份认证,与 401 类似,但请求者应当使用代理进行授权。
408 Request Time-out 服务器等待客户端发送的请求时间过长,超时。
409 Conflict 服务器完成客户端的 PUT 请求时可能返回此代码,服务器处理请求时发生了冲突。
410 Gone 客户端请求的资源已经不存在。410 不同于 404,如果资源以前有现在被永久删除了可使用 410 代码,网站设计人员可通过 301 代码指定资源的新位置。
411 Length Required 服务器无法处理客户端发送的不带 Content-Length 的请求信息。
412 Precondition Failed 客户端请求信息的先决条件错误。
413 Request Entity Too Large 由于请求的实体过大,服务器无法处理,因此拒绝请求。为防止客户端的连续请求,服务器可能会关闭连接。如果只是服务器暂时无法处理,则会包含一个 Retry-After 的响应信息。
414 Request-URI Too Large 请求的 URI 过长(URI 通常为网址),服务器无法处理。
415 Unsupported Media Type 服务器无法处理请求附带的媒体格式。
416 Requested range not satisfiable 客户端请求的范围无效。
417 Expectation Failed 服务器无法满足 Expect 的请求头信息。
421 Too Many Connections 从当前客户端所在的 IP 地址到服务器的连接数超过了服务器许可的最大范围。
422 Unprocessable Entity 请求格式正确,但是由于含有语义错误,无法响应。(RFC 4918 WebDAV)
423 Locked 当前资源被锁定。(RFC 4918 WebDAV)
424 Failed Dependency 由于之前的某个请求发生的错误,导致当前请求失败,例如 PROPPATCH。(RFC 4918 WebDAV)
425 Unordered Collection 在 WebDav Advanced Collections 草案中定义,但是未出现在《WebDAV 顺序集协议》(RFC 3658)中。
426 Upgrade Required 客户端应当切换到 TLS/1.0。(RFC 2817)
449 Retry With 由微软扩展,代表请求应当在执行完适当的操作后进行重试。
451 Unavailable For Legal Reasons 该请求因法律原因不可用。(RFC 7725)
500 Internal Server Error 服务器内部错误,无法完成请求。
501 Not Implemented 服务器不支持请求的功能,无法完成请求。
502 Bad Gateway 作为网关或者代理工作的服务器尝试执行请求时,从远程服务器接收到了一个无效的响应。
503 Service Unavailable 由于超载或系统维护,服务器暂时的无法处理客户端的请求。延时的长度可包含在服务器的 Retry-After 头信息中。
504 Gateway Time-out 充当网关或代理的服务器,未及时从远端服务器获取请求。
505 HTTP Version not supported 服务器不支持请求的 HTTP 协议的版本,无法完成处理。
506 Variant Also Negotiates 由《透明内容协商协议》(RFC 2295)扩展,代表服务器存在内部配置错误。
507 Insufficient Storage 服务器无法存储完成请求所必须的内容。这个状况被认为是临时的。WebDAV (RFC 4918)
509 Bandwidth Limit Exceeded 服务器达到带宽限制。这不是一个官方的状态码,但是仍被广泛使用。
510 Not Extended 获取资源所需要的策略并没有没满足。(RFC 2774)
600 Unparseable Response Headers 源站没有返回响应头部,只返回实体内容。

2.1.3 首部字段

2.1.3.1 通用首部字段

首部字段名称 说明
Cache-Control 控制缓存的行为。
Connection 逐跳首部、连接的管理。
Date 创建报文的日期时间。
Pragma 报文指令。
Trailer 报文末端的首部一览。
Transfer-Encoding 指定报文主体的传输编码方式。
Upgrade 升级为其他协议。
Via 代理服务器的相关信息。
Waring 错误通知。
2.1.3.1.1 Cache-Control
缓存请求指令 参数 说明
no-cache 强制向源服务器再次验证。
no-store 不缓存请求或响应的任何内容。
max-age=[秒] 必须 响应的最大 Age 值。
max-stale=[秒] 可省略 接收已过期的响应。
min-fresh=[秒] 必须 期望在指定时间内的响应仍有效。
no-transform 代理不可更改媒体类型。
only-if-cached 从缓存获取资源。
cache-extension - 新指令标记(token)。
缓存响应指令 参数 说明
public 可向任意方提供响应的缓存。
private 可省略 仅向特定用户返回响应。
no-cache 可省略 缓存前必须先确认其有效性。
no-store 不缓存请求或响应的任何内容。
no-transform 代理不可更改媒体类型。
must-revalidate 可缓存但必须再向源服务器进行确认。
proxy-revalidate 要求中间缓存服务器对缓存的响应有效性再进行确认。
max-age=[秒] 必须 响应的最大 Age 值。
s-maxage=[秒] 必须 公共缓存服务器响应的最大 Age 值。
cache-extension - 新指令标记(token)。

表示是否能缓存的指令

当指定 public 指令时,则明确表示其他用户也可利用缓存。

Cache-Control:public 
Cache-Control:private 
Cache-Control:no-cache
Cache-Control:no-cache=Location
Cache-Control:no-store

指定缓存期限和认证的指令

Cache-Control:s-maxage=3600
Cache-Control:max-age=3600
Cache-Control:min-fresh=60
Cache-Control:max-stale=3600
Cache-Control:only-if-cached
Cache-Control:must-revalidate
Cache-Control:no-transform
Cache-Control:private,community="UCI"
2.1.3.1.2 Connection

控制不再转发给代理的首部字段

Connection:Upgrade (不再转发的首部字段名)
//操作方式是将首部字段 Upgrade 删除后再转发

管理持久连接

Connection:Close
Keep-Alive:timeout=10,max=500
Connection:Keep-Alive
2.1.3.1.3 Date
Date:Tue,03 Jul 2012 04:40:59 GMT
Date:Tue,03-Jul-12 04:40:59 GMT
2.1.3.1.4 Pragma
Pragma:no-cache
Cache-Control:no-cache
Pragma:no-cache
2.1.3.1.5 Trailer
Trailer
2.1.3.1.6 Transfer-Encoding
Transfer-Encoding
2.1.3.1.7 Upgrade
2.1.3.1.8 Via
2.1.3.1.9 Warnning
警告码 警告内容 说明
110 Response is stale(响应已过期) 代理返回已过期的资源。
111 Revalidation failed(再验证失败) 代理再验证资源有效性时失败(服务器无法到达等原因)。
112 Disconnectio operation(断开连接操作) 代理与互联网连接被故意切断。
113 Heuristic expiration(试探性过期) 响应的使用期超过 24 小时(有效缓存的设定时间大于 24 小时的情况下)。
199 Miscellaneous warning(杂项警告) 任意的警告内容。
214 TransFormaction applied(使用了转换) 代理对内容编码或媒体类型等执行了某些处理时。
299 Miscellaneous persistent warning(持久杂项警告) 任意的警告内容。

2.1.3.2 请求首部字段

首部字段名称 说明
Accept 用户代理可处理的媒体类型。
Accept-Charset 优先的字符集。
Accept-Encoding 优先的内容编码。
Accept-Language 优先的语言(自然语言)。
Authorization Web 认证信息。
Expect 期待服务器的特定行为。
From 用户的电子邮箱地址。
Host 请求资源所在服务器。
If-Match 比较实体标记(ETag)。
If-Modified-Since 比较资源的更新时间。
If-None-Match 比较实体标记(与 If-Match 相反)。
If-Range 资源未更新时发送实体 Byte 的范围请求。
If-Unmodified-Since 比较资源的更新时间(与 If-Modified-Since 相反)。
Max-Forwards 最大传输逐跳数。
Proxy-Authorization 代理服务器要求客户端的认证信息。
Range 实体的字节范围请求。
Referer 对请求中 URI 的原始获取方。
TE 传输编码的优先级。
User-Agent HTTP 客户端程序的信息。
2.1.3.2.1 Accept
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
2.1.3.2.2 Accept-Charset
Accept-Charset:iso-8859-5,unicode-1-1;q=0.8
2.1.3.2.3 Accept-Encoding
Accept-Encoding:gzip,deflate
2.1.3.2.4 Accept-Language
Accept-Language:zh-cn,zh;q=0.7,en-us,en;q=0.3
2.1.3.2.5 Authorization
Authorization:Basic dWVub3N1bjpwYXNzd29yZA==
2.1.3.2.6 From
From:info@qq.com
2.1.3.2.7 Host
Host:www.adcd.com
2.1.3.2.8 If-Match
If-Match:"123456"
2.1.3.2.9 If-None-Match
If-None-Match:*
2.1.3.2.10 If-Modified-Since
If-Modified-Since:Thu,15 Apr 2004 00:00:00 GMT
2.1.3.2.11 If-Unmodified-Since
If-Modified-Since:Thu,15 Apr 2004 00:00:00 GMT
2.1.3.2.12 If-Range
If-Range:"123456"
Range:bytes=5001-10000
2.1.3.2.13 Max-Forwards
Max-Forwards:10
2.1.3.2.14 Proxy-Authorization
Proxy-Authorization: Basic dGlwOjkpNLAGfFY5
2.1.3.2.15 Range
Range:bytes=5001-10000
2.1.3.2.16 Referer
Referer: http://www.hackr.jp/index.htm
2.1.3.2.17 TE
TE: gzip, deflate;q=0.5
2.1.3.2.18 User-Agent
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:13.0) Gecko/201001

2.1.3.3 响应首部字段

首部字段名称 名称
Accept-Ranges 是否接受字节范围请求。
Age 推算资源创建经过时间。
ETag 资源的匹配信息。
Location 令客户端重定向至指定 URI。
Proxy-Authenticate 代理服务器对客户端的认证信息。
Retry-After 对再次发起请求的时机要求。
Server HTTP 服务器的安装信息。
Vary 代理服务器缓存的管理信息。
WWW-Authenticate 服务器对客户端的认证信息。
2.1.3.3.1 Accept-Ranges
Accept-Ranges: bytes
2.1.3.3.2 Age
Age:600
2.1.3.3.3 ETag
ETag: "82e22293907ce725faf67773957acd12"
ETag: "usagi-1234"
ETag: W/"usagi-1234"
Proxy-Authenticate: Basic realm="Usagidesign Auth"
2.1.3.3.4 Location
Location: http://www.usagidesign.jp/sample.html
2.1.3.3.5 Proxy-Authenticate
Proxy-Authenticate: Basic realm="Usagidesign Auth"
2.1.3.3.6 Retry-After
Retry-After: 120
2.1.3.3.7 Server
Server: Apache/2.2.17 (Unix)
2.1.3.3.8 Vary
Vary: Accept-Language
2.1.3.3.9 WWW-Authenticate
WWW-Authenticate: Basic realm="Usagidesign Auth"

2.1.3.4 实体首部字段

首部字段名称 说明
Allow 资源可支持的 HTTP 方法。
Content-Encoding 实体主体适用的编码方式。
Content-Language 实体主体的自然语言。
Content-Location 替代对应资源的 URI。
Content-MD5 实体主体的报文摘要。
Content-Range 实体主体的位置范围。
Content-Type 实体主体的媒体类型。
Expires 实体主体过期的日期时间。
Last-Modified 资源的最后修改日期时间。
2.1.3.4.1 Allow
Allow: GET, HEAD
2.1.3.4.2 Content-Encoding
Content-Encoding: gzip
2.1.3.4.3 Content-Language
Content-Language: zh-CN
2.1.3.4.4 Content-Length
Content-Length: 15000
2.1.3.4.5 Content-Location
Content-Location: http://www.hackr.jp/index-ja.html
2.1.3.4.6 Content-MD5
Content-MD5: OGFkZDUwNGVhNGY3N2MxMDIwZmQ4NTBmY2IyTY==
2.1.3.4.7 Content-Range
Content-Range: bytes 5001-10000/10000
2.1.3.4.8 Content-Type
Content-Type: text/html; charset=UTF-8
2.1.3.4.8 Expires
Expires: Wed, 04 Jul 2012 08:26:05 GMT
2.1.3.4.9 Last-Modified
Last-Modified: Wed, 23 May 2012 09:59:55 GMT

2.1.3.5 为 Cookie 服务的首部字段

2.1.3.5.1 Set-Cookie
Set-Cookie: status=enable; expires=Tue, 05 Jul 2011 07:26:31 GMT; pat
属性 说明
NAME=VALUE 赋予 Cookie 的名称和其值(必需项)。
expires=DATE Cookie 的有效期(若不明确指定则默认为浏览器关闭前为止)。
path=PATH 将服务器上的文件目录作为 Cookie 的适用对象(若不指定则默认为文档所在的文件目录)。
domain=域名 作为 Cookie 适用对象的域名(若不指定则默认为创建 Cookie 的服务器的域名)。
Secure 仅在 HTTPS 安全通信时才会发送 Cookie。
HttpOnly 加以限制,使 Cookie 不能被 JavaScript 脚本访问。
2.1.3.5.2 Cookie
Cookie: status=enable

2.1.3.6 其他首部字段

2.1.3.6.1 X-Frame-Options
X-Frame-Options: DENY
2.1.3.6.2 X-XSS-Protection
X-XSS-Protection: 1
2.1.3.6.3 DNT
DNT: 1
2.1.3.6.4 P3P
P3P: CP="CAO DSP LAW CURa ADMa DEVa TAIa PSAa PSDa IVAa IVDa OUR BUS I

2.1.3.7 浏览器的同源策略及跨域请求

CORS 的预请求

首部字段名称 说明
Access-Control-Request-Method 本次预请求的请求方法。
Access-Control-Request-Headers 本次请求所携带的自定义首部字段。
首部字段名称 说明
Access-Control-Allow-Origin 服务器允许的跨域请求源。
Access-Control-Allow-Methods 服务器允许的请求方法。
Access-Control-Allow-Headers 服务器允许的自定义的请求首部字段。
2.1.3.7.1 HTTP 请求首部字段

Origin

Origin: <origin>

Access-Control-Request-Method

Access-Control-Request-Method: <method>

Access-Control-Request-Headers

Access-Control-Request-Headers: <field-name>[, <field-name>]*
2.1.3.7.2 HTTP 响应首部字段

Access-Control-Allow-Origin

Access-Control-Allow-Origin: <origin> | *

Access-Control-Expose-Headers

Access-Control-Expose-Headers: X-My-Custom-Header, X-Another-Custom-Header

Access-Control-Max-Age

Access-Control-Max-Age: <delta-seconds>

Access-Control-Allow-Credentials

Access-Control-Allow-Credentials: true

Access-Control-Allow-Methods

Access-Control-Allow-Methods: <method>[, <method>]*

Access-Control-Allow-Headers

Access-Control-Allow-Headers: <field-name>[, <field-name>]*
上一篇 下一篇

猜你喜欢

热点阅读