《图解HTTP》学习笔记

书籍信息:《图解HTTP》作者:上野宣,译者:于均良
出版社:人民邮电出版社,2014年5月第1版


你一定见过这些数字:404、500、502……它们就像互联网的表情包,用三个数字告诉你发生了什么。200 是"没问题老铁",404 是"你找啥呢",500 是"我裂开了"。今天我们就来把这些状态码翻译成人话,顺便聊聊为什么你的接口明明报错了,前端却收到的全是 200。


第4章 返回结果的HTTP状态码

📌 核心知识点

  • 状态码的职责:当客户端向服务器发送请求时,描述返回的请求结果,告知用户服务器是正常处理了请求还是出现了错误。

  • 状态码格式:以3位数字和原因短语组成,第一位数字指定响应类别。

  • 5种状态码类别

类别 描述
1XX Informational(信息性状态码)- 接收的请求正在处理
2XX Success(成功状态码)- 请求正常处理完毕
3XX Redirection(重定向状态码)- 需要进行附加操作以完成请求
4XX Client Error(客户端错误状态码)- 服务器无法处理请求
5XX Server Error(服务器错误状态码)- 服务器处理请求出错
  • 2XX 成功状态码

  • 200 OK:请求已正常处理。GET方法返回对应实体;HEAD方法只返回首部。

  • 204 No Content:请求处理成功,但不含实体主体。适用于客户端向服务器发送信息但不需要返回新内容的场景(如表单提交后的成功反馈)。

  • 206 Partial Content:客户端进行了范围请求,服务器成功执行了部分GET请求。响应包含Content-Range指定范围的实体内容。

  • 3XX 重定向状态码

注意:301、302、303响应返回时,几乎所有浏览器都会把POST改成GET并删除请求主体,尽管标准禁止这样做。

  • 301 Moved Permanently:永久性重定向,资源已分配新URI,应更新书签。如URI末尾缺少斜杠/时常触发。

  • 302 Found:临时性重定向,资源临时分配了新URI,书签不应更新。

  • 303 See Other:与302类似,但明确表示应使用GET方法获取资源。常用于POST提交后重定向到结果页面。

  • 304 Not Modified:附带条件的请求(含If-Match、If-Modified-Since等首部),资源未满足条件。不包含响应主体,与重定向无关。

  • 307 Temporary Redirect:与302含义相同,但遵照标准不会将POST变成GET。

  • 4XX 客户端错误状态码

  • 400 Bad Request:请求报文存在语法错误,需修改后重新发送。浏览器会像200 OK一样处理。

  • 401 Unauthorized:请求需要HTTP认证(BASIC认证、DIGEST认证)。第一次返回401表示需要认证,第二次返回401表示认证失败。必须包含WWW-Authenticate首部。

  • 403 Forbidden:服务器拒绝了对请求资源的访问。未获得文件系统授权、访问权限问题等都可能触发。

  • 404 Not Found:服务器上无法找到请求的资源。也可在服务器拒绝请求且不想说明理由时使用。

  • 5XX 服务器错误状态码

  • 500 Internal Server Error:服务器执行请求时发生错误,可能是Web应用bug或临时故障。

  • 503 Service Unavailable:服务器暂时超负载或正在停机维护,无法处理请求。最好写入Retry-After首部告知客户端何时重试。

  • 状态码与实际状况的不一致:Web应用内部错误时仍返回200 OK的情况经常遇到,这是开发中需要特别注意的问题。

💻 实践用例

1. 使用curl查看不同状态码的响应

# 200 OK - 正常请求
curl -o /dev/null -w "状态码: %{http_code}\n" http://www.example.com/

# 301/302 - 观察重定向行为
curl -v http://github.com 2>&1 | grep -E "HTTP/|Location:"

# 404 Not Found
curl -o /dev/null -w "状态码: %{http_code}\n" http://www.example.com/not-exist-page

# 500 Internal Server Error(可使用httpbin测试)
curl -o /dev/null -w "状态码: %{http_code}\n" http://httpbin.org/status/500

2. 测试范围请求与206状态码

# 发送范围请求,应返回206 Partial Content
curl -I -H "Range: bytes=0-99" http://httpbin.org/robots.txt

# 输出中应包含:
# HTTP/1.1 206 Partial Content
# Content-Range: bytes 0-99/...

3. 测试304 Not Modified(条件请求)

# 第一次请求,记录Last-Modified时间
curl -I http://www.example.com/ 2>&1 | grep -i "last-modified"

# 使用If-Modified-Since发送条件请求
curl -I -H 'If-Modified-Since: Fri, 31 Aug 2007 02:02:20 GMT' http://www.example.com/
# 如果资源未修改,返回 304 Not Modified

4. 测试401 Unauthorized认证

# 访问需要认证的页面
curl -v http://httpbin.org/basic-auth/user/passwd
# 返回 401 Unauthorized 和 WWW-Authenticate 首部

# 提供认证信息后重试
curl -v -u user:passwd http://httpbin.org/basic-auth/user/passwd
# 返回 200 OK

5. 使用curl测试各种HTTP状态码

# httpbin.org 提供了便捷的状态码测试接口
for code in 200 204 301 302 304 400 401 403 404 500 503; do
  echo -n "状态码 $code: "
  curl -o /dev/null -s -w "%{http_code}" http://httpbin.org/status/$code
  echo
done

📝 学习笔记

  • 状态码是API设计的重要规范:在RESTful API开发中,正确使用状态码能让客户端准确判断请求结果。常见错误是将所有响应都返回200,而在响应体中用自定义字段表示错误。正确做法是:成功返回2XX,客户端参数错误返回400,未认证返回401,无权限返回403,资源不存在返回404,服务器错误返回500。

  • 301 vs 302 的SEO影响:301永久重定向会将搜索引擎的权重转移到新URL,302临时重定向则不会。在网站改版迁移URL时,应使用301而非302。

  • 304状态码与缓存性能:304是浏览器缓存机制的核心。当浏览器本地有缓存时,会发送附带条件(If-Modified-Since、If-None-Match)的请求,服务器返回304表示缓存仍有效,浏览器直接使用本地缓存,节省带宽。合理配置缓存策略能大幅提升网站性能。

  • 401 vs 403 的区别:401表示"我不知道你是谁"(未认证),403表示"我知道你是谁,但你没有权限"(已认证但无授权)。这个区分在实际开发中经常被混淆。

  • 503应配合Retry-After使用:当服务器需要维护或过载时,返回503并设置Retry-After首部,告知客户端何时可以重试。这是优雅降级的重要实践。

  • 状态码不一致是常见问题:书中提到"Web应用内部错误时仍返回200 OK"的情况经常遇到。这是前端开发中的痛点——需要额外判断响应体中的业务状态码。建议后端API在业务逻辑错误时返回4XX状态码,而非统一返回200。


状态码这东西,用对了是 API 的门面,用错了就是前端的噩梦。记住一个原则:该报错就报错,别什么都返回 200。你的同事会感谢你的。下一章我们离开协议本身,看看 HTTP 是怎么跟各种 Web 服务器打配合的。

Logo

openEuler 是由开放原子开源基金会孵化的全场景开源操作系统项目,面向数字基础设施四大核心场景(服务器、云计算、边缘计算、嵌入式),全面支持 ARM、x86、RISC-V、loongArch、PowerPC、SW-64 等多样性计算架构

更多推荐