读书笔记
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) |