HTTP的状态码有哪些,并用例子说明一下

HTTP状态码是服务器对客户端请求的响应码,它们按照不同的功能被分为五大类。我来介绍一下主要的状态码及其实际应用场景:

1xx(信息性状态码):表示请求已接收,需要继续处理。

  • 100 Continue:服务器已收到请求的初始部分,客户端应继续发送剩余请求。比如当上传大文件前,客户端可以先发送带有"Expect: 100-continue"头的请求,服务器回应100后再开始上传,避免不必要的数据传输。
  • 101 Switching Protocols:服务器同意切换协议。例如,客户端请求从HTTP切换到WebSocket时,服务器会返回101。

2xx(成功状态码):表示请求已成功接收、理解和处理。

  • 200 OK:最常见的成功状态码,表示请求成功。例如,当你访问一个网页并成功加载时,服务器返回200。
  • 201 Created:请求已完成,并创建了新资源。例如,通过POST请求创建新用户后,返回201和新用户的URL。
  • 204 No Content:服务器成功处理了请求,但不需要返回任何内容。例如,删除操作成功后可以返回204。

3xx(重定向状态码):表示客户端需要采取进一步操作才能完成请求。

  • 301 Moved Permanently:资源已永久移动到新位置。例如,网站域名变更后,旧域名会返回301并指向新域名,搜索引擎会更新索引。
  • 302 Found:资源临时位于不同的URL。例如,未登录用户访问需要权限的页面,被重定向到登录页面。
  • 304 Not Modified:资源未修改,可使用缓存版本。例如,浏览器发送带有If-Modified-Since头的请求,如果内容未变,服务器返回304,浏览器使用缓存。

4xx(客户端错误状态码):表示客户端请求有错误。

  • 400 Bad Request:请求语法错误。例如,提交表单时数据格式不正确。
  • 401 Unauthorized:需要身份验证。例如,访问需要登录的API时未提供有效的认证信息。
  • 403 Forbidden:服务器理解请求但拒绝执行。例如,用户尝试访问没有权限的资源。
  • 404 Not Found:服务器找不到请求的资源。例如,用户访问了不存在的URL。
  • 429 Too Many Requests:用户在给定时间内发送了太多请求。例如,API限制每分钟最多100个请求,超出后返回429。

5xx(服务器错误状态码):表示服务器在处理请求时发生错误。

  • 500 Internal Server Error:服务器遇到意外情况。例如,代码中出现未捕获的异常。
  • 502 Bad Gateway:作为网关的服务器从上游服务器收到无效响应。例如,Nginx代理后端服务时,后端服务崩溃了。
  • 503 Service Unavailable:服务器暂时不可用。例如,服务器正在维护或过载。
  • 504 Gateway Timeout:作为网关的服务器未及时从上游服务器收到响应。例如,Nginx等待后端服务响应超时。

在实际工作中,了解这些状态码非常重要。比如,我曾经看到一个问题,用户反馈某些图片无法加载。通过检查网络请求,发现这些请求返回了304状态码,但客户端缓存已损坏。解决方法是在请求URL添加版本参数,强制服务器返回200和完整内容。

正确理解和使用HTTP状态码,可以帮助我们设计更好的API,实现更有效的错误处理,并提高系统的可维护性。

00IC-EPM240程序例子说明

相关推荐
18538162800余+1 分钟前
深入解析:什么是矩阵系统源码搭建定制化开发,支持OEM贴牌
java·服务器·html
李昊哲小课1 分钟前
Spring Boot 基础教程
java·大数据·spring boot·后端
code123135 分钟前
tomcat升级操作
java·tomcat
TanYYF13 分钟前
HttpServletRequestWrapper详解
java·servlet
Swift社区20 分钟前
Spring Boot 3.x + Security + OpenFeign:如何避免内部服务调用被重复拦截?
java·spring boot·后端
小何好运暴富开心幸福1 小时前
操作系统之初识Linux
linux·运维·服务器·bash
阿波罗尼亚1 小时前
复杂查询:直接查询/子查询/视图/CTE
java·前端·数据库
goTsHgo1 小时前
Spring XML 配置简介
xml·java·spring
青柠编程1 小时前
基于 Spring Boot 的医疗病历信息交互平台架构设计
java·spring boot·后端
专注代码七年2 小时前
IDEA JVM优化配置idea64.vmoptions - 保守兼容版本 兼容IDEA 2023.3.6版本【亲测可用】
java·jvm·intellij-idea