《图解HTTP》第4章 返回结果的HTTP状态码

《图解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 服务器打配合的。

相关推荐
一马平川的大草原1 天前
报告笔记--AI工程的文化研读记录及感悟
人工智能·笔记·读书笔记
lunzi_fly6 天前
第2章-简单的HTTP协议
读书笔记
lunzi_fly13 天前
第1章-了解Web及网络基础
读书笔记
程序媛一枚~21 天前
202611读书笔记|《飞花令·柏》——身如古柏童童老,心似平江湛湛流
读书笔记·诗集·诗词·飞花令·素心落雪
Better Bench1 个月前
《八十天环游地球》阅读笔记
笔记·读书笔记·八十天环游地球
雷工笔记1 个月前
以复盘为镜,赴自我蜕变之约——《复盘自己:从记录到蜕变的行动指南》读书笔记
读书笔记
Rubin智造社2 个月前
Dankoe新作《使命与收益》读书笔记9|AI时代,写作是比编程更核心的元技能
人工智能·读书笔记·dankoe·个人公司·元能力·使命与收益
躺柒5 个月前
2025年总结及2026年目标之关键字【保持】
读书笔记·个人总结·随笔·年度总结·目标·工作总结·未来计划
躺柒5 个月前
2025年12月总结及随笔之海市蜃楼
人工智能·程序人生·读书笔记·个人总结·随笔