”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > API 设计中 HTTP 状态代码的终极参考

API 设计中 HTTP 状态代码的终极参考

发布于2024-11-17
浏览:925

The Ultimate Reference for HTTP Status Codes in API Design

在 Web 开发和 API 设计领域,HTTP 状态代码在客户端和服务器之间传达请求结果方面发挥着至关重要的作用。这些代码提供了一种标准化的方式来指示在处理 HTTP 请求期间发生的特定条件、成功或错误。了解这些状态代码对于开发人员至关重要,因为它有助于调试、错误处理和创建更强大的应用程序。

1. 1xx 信息

这些状态代码表示临时响应。它们在实践中很少使用,但在某些情况下可能会有所帮助。

  • 100 Continue:服务器已收到请求标头,客户端应继续发送请求正文。
  • 101 Switching Protocols:请求者要求服务器切换协议并且服务器已同意这样做。

2. 2xx 成功

这些状态代码表明客户端的请求已成功接收、理解并接受。

  • 200 OK:请求成功,响应中包含请求的数据或结果。
    • 示例:检索用户的个人资料信息。
  • 201 Created:请求成功,创建了新资源。
    • 示例:创建新用户帐户或发布新博客条目。
  • 204 No Content:服务器成功处理请求,但没有返回任何内容。
    • 示例:更新不需要响应正文的用户设置。
  • 206 部分内容:由于客户端发送的范围标头,服务器仅传送部分资源。
    • 示例:流式传输视频内容或分块下载大文件。

3. 3xx重定向

这些状态代码表明用户代理需要采取进一步的操作来满足请求。

  • 301 Moved Permanently:请求的资源已永久移动到新的URL。
  • 302 Found:请求的资源暂时驻留在不同的 URL 下。
  • 304 Not Modified:表示资源自请求头指定的版本以来尚未被修改。

4. 4xx客户端错误

这些状态代码适用于客户端似乎犯了错误的情况。

  • 400 Bad Request:由于语法无效或输入错误,服务器无法处理请求。

    • 示例:在请求正文中发送格式错误的 JSON。
    • 用法:当请求本身格式错误或包含无效参数时使用。
  • 401 Unauthorized:请求需要用户认证。

    • 示例:尝试在不提供有效凭据的情况下访问受保护的 API 端点。
    • 用途:需要身份验证且未提供或无效时使用。
  • 403 Forbidden:服务器理解请求,但拒绝授权。

    • 示例:用户尝试访问仅限管理员的功能。
    • 用法:当用户通过身份验证但无权执行请求的操作时使用。
  • 404 Not Found:在服务器上找不到请求的资源。

    • 示例:尝试检索已删除的用户配置文件。
    • 用法:当请求的资源不存在时使用。
  • 405 Method Not allowed:请求 URI 标识的资源不允许使用请求中指定的方法。

    • 示例:向仅接受 GET 请求的端点发送 POST 请求。
  • 409 冲突:由于与资源的当前状态冲突,无法处理请求。

    • 示例:尝试使用系统中已存在的电子邮件创建用户。
    • 用法:与资源当前状态存在冲突时使用,例如重复条目。
  • 422 Unprocessable Entity:服务器理解请求的内容类型和语法,但无法处理其中包含的指令。

    • 示例:提交包含无效数据的表单,导致服务器端验证失败。
    • 用法:用于请求语法正确但数据语义不正确的验证错误。
  • 429 Too Many Requests:用户在给定时间内发送了太多请求(“速率限制”)。

    • 示例:实施 API 速率限制以防止滥用。

5. 5xx服务器错误

这些状态代码指示服务器知道它遇到错误或无法执行请求的情况。

  • 500 内部服务器错误:一般错误消息,指示服务器遇到意外情况,导致其无法满足请求。

    • 示例:服务器端代码中发生未处理的异常。
  • 501 Not Implemented:服务器不支持满足请求所需的功能。

    • 示例:使用服务器无法识别的新 HTTP 方法。
  • 502 Bad Gateway:服务器在充当网关或代理时,从上游服务器收到无效响应。

    • 示例:反向代理服务器无法连接到源服务器。
  • 503 Service Unavailable:由于临时过载或维护,服务器当前无法处理请求。

    • 示例:服务器正在进行定期维护或遇到高流量。
  • 504 Gateway Timeout:服务器作为网关或代理时,没有及时收到上游服务器的响应。

    • 示例:等待第三方API响应超时。

使用 HTTP 状态代码的最佳实践

  1. 具体:使用适用于具体情况的最具体的状态代码。这有助于客户准确了解发生了什么以及如何应对。

  2. 一致的用法:保持 API 中状态代码使用方式的一致性。这使开发人员可以更轻松地使用您的 API。

  3. 提供附加信息:与状态代码一起,在适当的情况下在响应正文中包含详细的错误消息。这可以帮助调试并改善开发人员体验。

  4. 安全注意事项:请谨慎,不要在错误响应中泄露太多信息,尤其是 4xx 和 5xx 错误。避免暴露有关系统架构或实现的敏感细节。

  5. 文档:清楚地记录您的 API 使用哪些状态代码以及在什么情况下使用。这有助于 API 使用者了解如何解释和处理不同的响应。

通过理解并正确实现 HTTP 状态代码,开发人员可以创建更健壮、清晰且用户友好的 API 和 Web 应用程序。这些代码充当客户端和服务器之间的重要通信工具,有助于简化错误处理并提高整体系统可靠性。

版本声明 本文转载于:https://dev.to/shanu001x/the-ultimate-reference-for-http-status-codes-in-api-design-77b?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为 bool 的主要场景:语句:if、w...
    编程 发布于2024-11-18
  • 如何在 Chrome 实验功能中使用 JavaScript 从浏览器连接到 TCP 套接字?
    如何在 Chrome 实验功能中使用 JavaScript 从浏览器连接到 TCP 套接字?
    使用 JavaScript 从浏览器连接到 TCP 套接字当您寻求在浏览器的 JavaScript 和 .NET 应用程序托管的 TCP 套接字之间建立双向通信时,当前的 Web 技术格局提出了挑战。到目前为止,流行的浏览器缺乏 JavaScript 的标准化套接字 API。然而,有希望的进展正在发...
    编程 发布于2024-11-18
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-18
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-18
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-11-18
  • 如果 Go 函数发生紧急情况,如何返回错误?
    如果 Go 函数发生紧急情况,如何返回错误?
    从 Go 中的 Defer 返回您遇到了这样的问题:如果 Go 中的函数发生紧急情况,您希望返回错误。这是对您的代码的分析和修复:func getReport(filename string) (rep report, err error) { rep.data = make(map[str...
    编程 发布于2024-11-18
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-11-17
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-17
  • 如何有效调试 Python 代码:实用技巧和工具
    如何有效调试 Python 代码:实用技巧和工具
    Python 调试:实用技巧和工具在对 Python 代码进行故障排除时,拥有一个可供使用的调试技术工具包至关重要。以下是一些非常有效的技巧:PDB:强大的断点工具利用 PDB 模块设置断点并获得对代码执行的控制。通过插入 pdb.set_trace(),可以在特定点暂停执行并检查程序的当前状态:i...
    编程 发布于2024-11-17
  • 如何在不重启服务器的情况下清除MySQL查询缓存?
    如何在不重启服务器的情况下清除MySQL查询缓存?
    在不恢复服务器的情况下减轻 MySQL 查询缓存尽管 MySQL 查询缓存提供了更高的性能,但在需要时可能会出现这种情况可以在不中断服务器运行的情况下进行清除。以下是实现此目的的一些方法:重置查询缓存如果执行命令的用户具有重新加载权限,则可以使用以下命令显式删除查询缓存命令:RESET QUERY ...
    编程 发布于2024-11-17
  • MySQL 如何处理表名和列名的区分大小写?
    MySQL 如何处理表名和列名的区分大小写?
    MySQL 中列名和表名的大小写敏感度MySQL 中的大小写敏感度主题可能会让许多用户感到困惑。了解列名和表名的大小写敏感性对于确保正确的数据库操作和避免潜在的陷阱至关重要。表名表名是否区分大小写取决于在运行 MySQL 服务器的操作系统上。在基于 Unix 的系统(例如 Linux)上,表名称区分...
    编程 发布于2024-11-17
  • 为什么将常量引用绑定到临时对象会延长其生命周期?
    为什么将常量引用绑定到临时对象会延长其生命周期?
    为什么将常量引用绑定到临时对象会延长临时对象的生命周期?C 编程语言允许常量引用来延长临时对象的生命周期。这种行为一直是很多争论的主题,一些人认为它可以提高代码设计的性能和灵活性。这种语言功能的起源可以追溯到 1993 年,当时它被提议作为以下问题的解决方案:绑定到引用时临时变量的处理不一致。在没有...
    编程 发布于2024-11-17
  • 如何在共享主机的子目录中托管 Laravel 项目而不在 URL 中暴露“/public”
    如何在共享主机的子目录中托管 Laravel 项目而不在 URL 中暴露“/public”
    在共享主机上托管 Laravel 项目时,一个常见的挑战是确保 URL 不需要 /public 目录。这是在子目录中托管 Laravel 应用程序同时保持 URL 干净的分步指南。 第 1 步:将 Laravel 项目上传到服务器 登录您的托管帐户并访问您的文件管理器。 导航到 pu...
    编程 发布于2024-11-17
  • 编码面试中解决问题的终极指南
    编码面试中解决问题的终极指南
    Common Strategies for Coding Interview Questions Two Pointers The two pointers technique is often used to solve array-related problem...
    编程 发布于2024-11-17
  • 为什么 ASAP (Atlassian) Auth 是 REST API 身份验证的快速且安全的选择?
    为什么 ASAP (Atlassian) Auth 是 REST API 身份验证的快速且安全的选择?
    作为一名广泛使用 API 的高级开发人员,安全性和效率始终是重中之重。在保护 REST API 方面,有多种身份验证方法可用,但并非所有方法都是相同的。 Atlassian 的 ASAP(服务和项目身份验证)Auth 作为一个强大、可扩展且安全的选项而脱颖而出,特别是在处理需要强大身份验证机制的...
    编程 发布于2024-11-17

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3