读书笔记
http:HyperText Transfer Protocol
1、返回结果的Http状态码
状态码的类别:
| 类别 | 原因短语 |
---|
1XX | Informational(信息性状态码) | 接收的请求正在处理 |
2XX | Success(成功状态码) | 请求正常处理完毕 |
3XX | Redirection(重定向状态码) | 需要进行附加操作以完成请求 |
4XX | Client Error(客户端错误状态码) | 服务器无法处理请求 |
5XX | Server Error(服务器错误状态码) | 服务器处理请求出错 |
注意:基于万维网的分布式创作和版本控制)(RFC4918、5842) 和附加 HTTP 状态码(RFC6585)等扩展,数量就达 60 余种.
常用的大概只有14种
常用的状态码14种
编号 | 描述 | 说明 |
---|
200 OK | 请求已经正常处理,有结果正常返回 | 返回结果随报文一起返回 |
204 No Content | 请求处理成功,返回的报文中不含实体的主体部分 | 浏览器页面不发生更新 |
206 Partial Content | 客户端进行范围请求,只想要一部分的内容,服务器响应请求,报文中包含content-Range实体内容 | |
301 Moved Permanently | 永久性重定向,请求的资源已被分配了新的 URI ,以后应使用资源现在所指的 URI | |
302 Found | 临时性重定向。请求的资源已被分配了新的 URI,希望用户(本次)能使用新的 URI 访问 | 和301相似 |
303See Other | 该状态码表示由于请求对应的资源存在着另一个 URI,应使用 GET方法定向获取请求的资源 | 先用get请求获取新的路径 |
304 Not Modified | 该状态码表示客户端发送附带条件的请求 2 时,服务器端允许请求访问资源,但未满足条件的情况。304 状态码返回时,不包含任何响应的主体部分。304 虽然被划分在 3XX 类别中,但是和重定向没有关系 | |
307 Temporary Redirect | 临时重定向。该状态码与 302 Found 有着相同的含义 | |
400 Bad Request | 该状态码表示请求报文中存在语法错误。当错误发生时,需修改请求的内容后再次发送请求。 | |
401 Unauthorized | 该状态码表示发送的请求需要有通过 HTTP 认证(BASIC 认证、DIGEST 认证)的认证信息。另外若之前已进行过 1 次请求,则表示用 户认证失败。 | |
403 Forbidden | 该状态码表明对请求资源的访问被服务器拒绝了。服务器端没有必要给出拒绝的详细理由,但如果想作说明的话,可以在实体的主体部分对原因进行描述,这样就能让用户看到了。 | |
404 Not Found | 该状态码表明服务器上无法找到请求的资源 | |
500 Internal Server Error | 该状态码表明服务器端在执行请求时发生了错误。也有可能是 Web应用存在的 bug 或某些临时的故障。 | |
503 Service Unavailable | 该状态码表明服务器暂时处于超负载或正在进行停机维护,现在无法处理请求。如果事先得知解除以上状况需要的时间,最好写入RetryAfter 首部字段再返回给客户端。 | |
-----HTTP首部
HTTP报文首部
1、报文首部
2、空行
3、报文主体
http协议的请求和响应都必须包含http首部;
分类 | 名称 |
---|
按请求响应分类 | http请求报文;http响应报文 |
0请求报文概述:
1、请求报文 = 请求报文头部 + 报文主体
请求报文首部组成:
请求行+
请求首部字段+
通用首部字段 +
实体首部字段
其他
2、响应报文 = 报文首部 + 报文主体
响应报文首部组成:
状态行:http版本和状态码
响应首部字段
通用首部字段
实体首部字段
其他
HTTP 首部字段根据实际用途被分为以下 4 种类型。
HTTP 首部字段 | 分类 | 描述 |
---|
| 通用首部字段(General Header Fields) | 请求报文和响应报文两方都会使用的首部。 |
| 请求首部字段(Request Header Fields) | 从客户端向服务器端发送请求报文时使用的首部。补充了请求的附加内容、客户端信息、响应内容相关优先级等信息。 |
| 响应首部字段(Response Header Fields) | 从服务器端向客户端返回响应报文时使用的首部。补充了响应的附加内容,也会要求客户端附加额外的内容信息。 |
| 实体首部字段(Entity Header Fields) | 针对请求报文和响应报文的实体部分使用的首部。补充了资源内容更新时间等与实体有关的信息。 |
1、通用首部字段(general header field)
首部字段名 | 说明 |
---|
Cache-Control | 控制缓存的行为 |
Connection | 逐跳首部、连接的管理 |
Date | 创建报文的日期时间 |
Pragma | 报文指令 |
Trailer | 报文末端的首部一览 |
Transfer-Encoding | 指定报文主体的传输编码方式 |
Upgrade | 升级为其他协议 |
Via | 代理服务器的相关信息 |
Warning | 错误通知 |
2、请求首部字段(request header field)
首部字段名 | 说明 |
---|
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 客户端程序的信息 |
3、响应首部字段(response header field)
首部字段名 | 说明 |
---|
Accept-Ranges | 是否接受字节范围请求 |
Age | 推算资源创建经过时间 |
ETag | 资源的匹配信息 |
Location | 令客户端重定向至指定URI |
Proxy-Authenticate | 代理服务器对客户端的认证信息 |
Retry-After | 对再次发起请求的时机要求 |
Server HTTP | 服务器的安装信息 |
Vary | 代理服务器缓存的管理信息 |
WWW-Authenticate | 服务器对客户端的认证信息 |
4、实体首部字段(entity header field)
首部字段名 | 说明 |
---|
Allow | 资源可支持的HTTP方法 |
Content-Encoding | 实体主体适用的编码方式 |
Content-Language | 实体主体的自然语言 |
Content-Length | 实体主体的大小(单位:字节) |
Content-Location | 替代对应资源的URI |
Content-MD5 | 实体主体的报文摘要 |
Content-Range | 实体主体的位置范围 |
Content-Type | 实体主体的媒体类型 |
Expires | 实体主体过期的日期时间 |
Last-Modified | 资源的最后修改日期时间 |
1.1 通用首部参数详解
1、cache-control
指令 | 参数 | 说明 |
---|
no-cache | 无 | 强制向源服务器再次验证 |
no-store | 无 | 不缓存请求或响应的任何内容 |
max-age = [ 秒] | 必需 | 响应的最大Age值 |
max-stale( = [ 秒]) | 可省略 | 接收已过期的响应 |
min-fresh = [ 秒] | 必需 | 期望在指定时间内的响应仍有效 |
no-transform | 无 | 代理不可更改媒体类型 |
only-if-cached | 无 | 从缓存获取资源 |
cache-extension | - | 新指令标记(token) |