」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > API 設計中 HTTP 狀態碼的終極參考

API 設計中 HTTP 狀態碼的終極參考

發佈於2024-11-17
瀏覽:887

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]刪除
最新教學 更多>
  • 如何從PHP中的數組中提取隨機元素?
    如何從PHP中的數組中提取隨機元素?
    從陣列中的隨機選擇,可以輕鬆從數組中獲取隨機項目。考慮以下數組:; 從此數組中檢索一個隨機項目,利用array_rand( array_rand()函數從數組返回一個隨機鍵。通過將$項目數組索引使用此鍵,我們可以從數組中訪問一個隨機元素。這種方法為選擇隨機項目提供了一種直接且可靠的方法。
    程式設計 發佈於2025-04-11
  • 如何使用組在MySQL中旋轉數據?
    如何使用組在MySQL中旋轉數據?
    在關係數據庫中使用mySQL組使用mySQL組進行查詢結果,在關係數據庫中使用MySQL組,轉移數據的數據是指重新排列的行和列的重排以增強數據可視化。在這裡,我們面對一個共同的挑戰:使用組的組將數據從基於行的基於列的轉換為基於列。 Let's consider the following ...
    程式設計 發佈於2025-04-11
  • 如何使用Python理解有效地創建字典?
    如何使用Python理解有效地創建字典?
    在python中,詞典綜合提供了一種生成新詞典的簡潔方法。儘管它們與列表綜合相似,但存在一些顯著差異。 與問題所暗示的不同,您無法為鑰匙創建字典理解。您必須明確指定鍵和值。 For example:d = {n: n**2 for n in range(5)}This creates a dict...
    程式設計 發佈於2025-04-11
  • 如何從PHP中的Unicode字符串中有效地產生對URL友好的sl。
    如何從PHP中的Unicode字符串中有效地產生對URL友好的sl。
    為有效的slug生成首先,該函數用指定的分隔符替換所有非字母或數字字符。此步驟可確保slug遵守URL慣例。隨後,它採用ICONV函數將文本簡化為us-ascii兼容格式,從而允許更廣泛的字符集合兼容性。 接下來,該函數使用正則表達式刪除了不需要的字符,例如特殊字符和空格。此步驟可確保slug僅包...
    程式設計 發佈於2025-04-11
  • PHP陣列鍵值異常:了解07和08的好奇情況
    PHP陣列鍵值異常:了解07和08的好奇情況
    PHP數組鍵值問題,使用07&08 在給定數月的數組中,鍵值07和08呈現令人困惑的行為時,就會出現一個不尋常的問題。運行print_r($月)返回意外結果:鍵“ 07”丟失,而鍵“ 08”分配給了9月的值。 此問題源於PHP對領先零的解釋。當一個數字帶有0(例如07或08)的前綴時,PHP將...
    程式設計 發佈於2025-04-11
  • 如何實時捕獲和流媒體以進行聊天機器人命令執行?
    如何實時捕獲和流媒體以進行聊天機器人命令執行?
    在開發能夠執行命令的chatbots的領域中,實時從命令執行實時捕獲Stdout,一個常見的需求是能夠檢索和顯示標準輸出(stdout)在cath cath cant cant cant cant cant cant cant cant interfaces in Chate cant inter...
    程式設計 發佈於2025-04-11
  • 如何干淨地刪除匿名JavaScript事件處理程序?
    如何干淨地刪除匿名JavaScript事件處理程序?
    刪除匿名事件偵聽器將匿名事件偵聽器添加到元素中會提供靈活性和簡單性,但是當要刪除它們時,可以構成挑戰,而無需替換元素本身就可以替換一個問題。 element? element.addeventlistener(event,function(){/在這里工作/},false); 要解決此問題,請考...
    程式設計 發佈於2025-04-11
  • 如何在鼠標單擊時編程選擇DIV中的所有文本?
    如何在鼠標單擊時編程選擇DIV中的所有文本?
    在鼠標上選擇div文本單擊帶有文本內容,用戶如何使用單個鼠標單擊單擊div中的整個文本?這允許用戶輕鬆拖放所選的文本或直接複製它。 在單個鼠標上單擊的div元素中選擇文本,您可以使用以下Javascript函數: function selecttext(canduterid){ if(d...
    程式設計 發佈於2025-04-11
  • 如何在php中使用捲髮發送原始帖子請求?
    如何在php中使用捲髮發送原始帖子請求?
    如何使用php 然後,配置以下選項: curlopt_url:請求 [要發送的原始數據指定內容類型,為原始的帖子請求指定身體的內容類型很重要。在這種情況下,它是文本/平原。要執行此操作,請使用包含以下標頭的數組使用curlopt_httpheader選項:響應將存儲在變量$ result。 示例代...
    程式設計 發佈於2025-04-11
  • 為什麼我在Silverlight Linq查詢中獲得“無法找到查詢模式的實現”錯誤?
    為什麼我在Silverlight Linq查詢中獲得“無法找到查詢模式的實現”錯誤?
    查詢模式實現缺失:解決“無法找到”錯誤在銀光應用程序中,嘗試使用LINQ建立錯誤的數據庫連接的嘗試,無法找到以查詢模式的實現。 ”當省略LINQ名稱空間或查詢類型缺少IEnumerable 實現時,通常會發生此錯誤。 解決問題來驗證該類型的質量是至關重要的。在此特定實例中,tblpersoon可能...
    程式設計 發佈於2025-04-11
  • 為什麼我會收到MySQL錯誤#1089:錯誤的前綴密鑰?
    為什麼我會收到MySQL錯誤#1089:錯誤的前綴密鑰?
    mySQL錯誤#1089:錯誤的前綴鍵錯誤descript [#1089-不正確的前綴鍵在嘗試在表中創建一個prefix鍵時會出現。前綴鍵旨在索引字符串列的特定前綴長度長度,可以更快地搜索這些前綴。 了解prefix keys `這將在整個Movie_ID列上創建標準主鍵。主密鑰對於唯一識...
    程式設計 發佈於2025-04-11
  • 為什麼PHP的DateTime :: Modify('+1個月')會產生意外的結果?
    為什麼PHP的DateTime :: Modify('+1個月')會產生意外的結果?
    使用php dateTime修改月份:發現預期的行為在使用PHP的DateTime類時,添加或減去幾個月可能並不總是會產生預期的結果。正如文檔所警告的那樣,“當心”這些操作的“不像看起來那樣直觀。 考慮文檔中給出的示例:這是內部發生的事情: 現在在3月3日添加另一個月,因為2月在2001年只有2...
    程式設計 發佈於2025-04-11
  • 如何克服PHP的功能重新定義限制?
    如何克服PHP的功能重新定義限制?
    克服PHP的函數重新定義限制在PHP中,多次定義一個相同名稱的函數是一個no-no。嘗試這樣做,如提供的代碼段所示,將導致可怕的“不能重新列出”錯誤。 但是,PHP工具腰帶中有一個隱藏的寶石:runkit擴展。它使您能夠靈活地重新定義函數。 runkit_function_renction_...
    程式設計 發佈於2025-04-11
  • 如何配置Pytesseract以使用數字輸出的單位數字識別?
    如何配置Pytesseract以使用數字輸出的單位數字識別?
    Pytesseract OCR具有單位數字識別和僅數字約束 在pytesseract的上下文中,在配置tesseract以識別單位數字和限制單個數字和限制輸出對數字可能會提出質疑。 To address this issue, we delve into the specifics of Te...
    程式設計 發佈於2025-04-11
  • 為什麼不````''{margin:0; }`始終刪除CSS中的最高邊距?
    為什麼不````''{margin:0; }`始終刪除CSS中的最高邊距?
    在CSS 問題:不正確的代碼: 全球範圍將所有餘量重置為零,如提供的代碼所建議的,可能會導致意外的副作用。解決特定的保證金問題是更建議的。 例如,在提供的示例中,將以下代碼添加到CSS中,將解決餘量問題: body H1 { 保證金頂:-40px; } 此方法更精確,避免了由全局保證金重置...
    程式設計 發佈於2025-04-11

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3