【一天一个知识点系列】- Http之状态码

  • 2021 年 1 月 21 日
  • 筆記

状态码

简介

  • HTTP 状态码负责表示客户端 HTTP 请求的返回结果、 标记服务器端的处理是否正常、 通知出现的错误等工作

作用及类别

  • 作用:状态码告知从服务器端返回的请求结果

  • 状态码的类别
  • 注意:只要遵守状态码类别的定义, 即使改变 RFC2616 中定义的状态码,或服务器端自行创建状态码都没问题

具体含义

2XX 成功

  • 含义:2XX 的响应结果表明请求被正常处理了
  • 类型:
    • 200 OK:表示从客户端发来的请求在服务器端被正常处理了
    • 状态码 200 附图
    • 204 No Content:该状态码代表服务器接收的请求已成功处理, 但在返回的响应报文中不含实体的主体部分,也不允许返回任何实体的主体
    • 状态码 204 附图
    • 206 Partial Content:表示客户端进行了范围请求, 而服务器成功执行了这部分的 GET 请求,响应报文中包含由 Content-Range 指定范围的实体内容
    • 状态码 206 附图

3XX 重定向

  • 含义:3XX 响应结果表明浏览器需要执行某些特殊的处理以正确处理请求
  • 类型:
    • 301 Moved Permanently:永久性重定向,表示请求的资源已被分配了新的 URI, 以后应使用资源现在所指的 URI
    • 状态码 301 附图
    • 302 Found:临时性重定向,表示请求的资源已被分配了新的 URI, 希望用户(本次) 能使用新的 URI 访问
    • 状态码 302 附图
    • 301302 区别:
      • 301 状态码代表的资源是被永久移动
      • 302 状态码代表的资源不是被永久移动, 只是临时性质的
    • 303 See Other:该状态码表示由于请求对应的资源存在着另一个 URI, 应使用 GET 方法定向获取请求的资源
    • 状态码 303 附图
    • 区别:303 状态码和 302 Found 状态码有着相同的功能, 但 303 状态码明确表示客户端应当采用 GET 方法获取资源, 这点与 302 状态码有区别
    • 注意:当 301、 302、 303 响应状态码返回时, 几乎所有的浏览器都会把 POST 改成 GET, 并删除请求报文内的主体, 之后请求会自动再次发送。301、 302 标准是禁止将 POST 方法改变成 GET 方法的, 但实际使用时大家都会这么做
    • 304 Not Modified:表示客户端发送附带条件的请求时, 服务器端允许请求访问资源, 但未满足条件的情况。 304 状态码返回时, 不包含任何响应的主体部分。 304 虽然被划分在 3XX 类别中, 但是和重定向没有关系
    • 状态码 304 附图
    • 附带条件的请求:附带条件的请求是指采用 GET 方法的请求报文中包含 If-Match,If-Modified-Since,If-None-Match,If-Range,If-Unmodified-Since 中任一首部
    • 307 Temporary Redirect:临时重定向,含义如302307 会遵照浏览器标准, 不会从 POST 变成 GET(尽管 302 标准禁止 POST 变换成 GET, 但实际使用时大家并不遵守)

4XX 客户端错误

  • 含义:4XX 的响应结果表明客户端是发生错误的原因所在
  • 类型:
    • 400 Bad Request :表示请求报文中存在语法错误。 当错误发生时, 需修改请求的内容后再次发送请求。 另外, 浏览器会像 200 OK 一样对待该状态码
    • 状态码 400 附图
    • 401 Unauthorized:表示发送的请求需要有通过 HTTP 认证(BASIC 认证、DIGEST 认证) 的认证信息。 另外若之前已进行过 1 次请求, 则表示用 户认证失败
    • 状态码 401 附图
    • 注意:返回含有 401 的响应必须包含一个适用于被请求资源的 WWWAuthenticate 首部用以质询(challenge) 用户信息。 当浏览器初次接收到 401 响应, 会弹出认证用的对话窗口
    • 403 Forbidden:表示对请求资源的访问被服务器拒绝了。 服务器端没有必要给出拒绝的详细理由, 但如果想作说明的话, 可以在实体的主体部分6对原因进行描述, 这样就能让用户看到了
    • 状态码 403 附图
    • 注意:未获得文件系统的访问授权, 访问权限出现某些问题(从未授权的发送源 IP 地址试图访问) 等列举的情况都可能是发生 403 的原因
    • 404 Not Found:表示服务器上无法找到请求的资源。 除此之外, 也可以在服务器端拒绝请求且不想说明理由时使用
    • 状态码 404 附图
    • 注意:该状态码表明服务器上无法找到请求的资源。 除此之外, 也可以在服务器端拒绝请求且不想说明理由时使用

5XX 服务器错误

  • 含义:5XX 的响应结果表明服务器本身发生错误
  • 类型:
    • 500 Internal Server Error:表示服务器端在执行请求时发生了错误。 也有可能是Web应用存在的 bug 或某些临时的故障
    • 状态码 500 附图
    • 503 Service Unavailable:表示服务器暂时处于超负载或正在进行停机维护, 现在无法处理请求。 如果事先得知解除以上状况需要的时间, 最好写入 RetryAfter 首部字段再返回给客户端
    • 状态码 503 附图

总结

  • 日常使用中,经常会有状态码和状况的不一致的情况。不少返回的状态码响应都是错误的, 但是用户可能察觉不到这点。使用时尽量遵循标准,才能一目了然