[Medium翻譯]RESTful API權威設計指南-設計更好的API

来源:https://www.cnblogs.com/luosiwang/archive/2018/07/28/9375427.html
-Advertisement-
Play Games

對於我們開發者來說,設計與實現REST API似乎已經成為了我們的日常生活。API現在已經成為了系統間互通的預設方式。AMAZON就是一個有效的使用API進行系統間溝通的最好的例子。在這篇文章中,我將重點討論如何幫助你設計更好的API並避免一些常見的誤區。 ...


本文為授權譯文。希望查看原文的同學請戳鏈接:https://hackernoon.com/restful-api-design-step-by-step-guide-2f2c9f9fcdbf

 

對於我們開發者來說,設計與實現REST API似乎已經成為了我們的日常生活。API現在已經成為了系統間互通的預設方式。AMAZON就是一個有效的使用API進行系統間溝通的最好的例子。在這篇文章中,我將重點討論如何幫助你設計更好的API並避免一些常見的誤區。

傑夫貝索斯的意志-亞麻的成功之路?

可能你已經大概瞭解了傑夫貝索斯對於亞馬遜開發者的要求。如果你還沒有聽過,以下就是要點:

  1. 所有的團隊今後必須通過服務介面來開放自己的數據和服務功能。
  2. 團隊間只能通過這些介面進行通信。
  3. 其他所有的方式都不被允許:不可以直鏈,不可以直接去讀取其他隊伍的數據源,不能通過共用記憶體通信,不可以通過服務後門通信。總之,只能通過網路介面進行服務間的通信。
  4. 任何實現介面的技術都是被允許的:HTTP,Corba,Pubsub,自定義協議。貝索斯不在乎具體的實現。
  5. 所有的介面都需要被設計成可暴露型,不允許任何特例。也就是說,所有的團隊都必須計劃將自己的服務介面設計成可以被暴露給狂野的外部世界的形式。
  6. 任何人不遵守以上協議的,就滾蛋吧。

 以上的要求現在看來正是亞馬遜成功的關鍵。亞馬遜在內部開發出可擴展的服務,成熟後就將這些服務暴露給外界使用。於是就有了我們所熟悉的強大的AWS。


RESTful API的設計原則

好吧,現在我們就開始瞭解一些我們設計RESTful API時需要遵守的一些原則。

能簡單就簡單 Keep It Simple

我們需要確保API的URL是簡單的。比如說,如果我們要設計一個關於產品的API,他應該是這樣的:

/products
/products/12345

第一個API用來返回所有的產品,第二個則用來返回特定的產品。

使用名詞而不是動詞

很多開發者會犯這個錯誤。他們大概忘了我們已經後HTTP的Methods來幫助我們表達動詞的部分。不如,一個用來得到所有產品的的API應該是:

/products

而不是

/getAllProducts

 使用正確的HTTP方法

RESTful API有不同的方法來標示這個API操作的類型:

  • GET-要從服務中得到某個或者一些數據
  • POST-要在服務中創建某個或者一些數據
  • PUT/PATCH-要更新服務中的某些已有的數據
  • DELETE-要刪除一些服務中已有的數據

我們需要確保我們在對應的API上使用正確的HTTP方法。

使用複數

這個觀點有一些爭議。有些人喜歡在設計URL時使用複數而有些人認為保持單數更合適。比如

/products
/product

我個人喜歡使用複數。原因呢就是這樣可以避免迷惑使用者這個API到底是要返回單個數據還是一個數據的集合。同時這樣的設計也可以避免需要在Base URL疊放額外的參數,比如:/product/all

有些人可能不喜歡這個建議。那我的意見是至少你要在一個Project中保持命名的統一。

使用參數

有時候我們需要設計更複雜的API。這些API不止需要傳入id,可能還要傳入更複雜的參數。這時,我們就應該使用參數來設計API,比如:

  • /products?name='ABC' 就要比 /getProductsByName 要更好
  • /products?type='xyz' 就要比 /getProductsByType 要更好

這樣你就可以避免使用很長的URL來表達自己的意圖。設計變得更簡潔。

使用合適的HTTP狀態碼

HTTP為我們提供了豐富的狀態返回碼。然而令人遺憾的是,我們大部分人只使用了其中的兩個-200和500!這肯定不是一個很好的實踐!一下就一些你可以馬上實用的HTTP狀態碼:

  • 200 OK-這是HTTP中最常用的狀態碼。用來標示所請求的操作成功了。
  • 201 CREATED-這個狀態碼標示你使用POST操作所創建的資源創建成功了。
  • 202 ACCEPTED-這個標示伺服器獲得並認可了你發送請求。
  • 400 BAD REQUEST-這個則用來標示用戶輸入的數據有誤。
  • 401 UNAUTHRORIZED/403 FORBINDDEN-這兩個狀態碼用來告訴用戶沒有許可權或者沒有被授權進行所請求的操作。
  • 404 NOT FOUND-這個狀態碼用來告訴用戶你想要尋找的資源並不存在。
  • 500 INTERNAL SERVER ERROR-你永遠不應該顯示的拋出這個異常。只有在系統異常出現時由系統自動拋出。
  • 502 BAD GATEWAY-如果從上游的服務中收到了任何異常或者不正確的響應,這是合適的選擇。

使用版本

使用版本對於API來說是很重要的!不同的企業有不同使用版本的習慣。有些使用日期來表示版本。有些則使用查詢參數來表示版本。我個人更喜歡把版本放到URL的首碼上。比如:

/v1/products
/v2/products

而且我會儘量避免使用小版本號/v1.2/products/。因為這樣會讓人覺得你的API會頻繁的變化。同時,(.)這個點並不是能夠很快的在URL中被看到。所以,還是越簡單越好吧!

同時,保持版本的向前相容是很重要的實踐。這樣即使你改變了API版本,你的客戶也有足夠的時間來跟進你所進行的變化。

使用分頁(Pagination)

當一個API可能會返回巨量數據的時候,使用分頁成為了必須。否則用戶可能會使伺服器崩潰。

We need to always keep in mind that the API design should be full proof and fool proof.

我推薦使用limit和offset這兩個參數。比如,/products?limit=25&offset=50 同時你也要考慮設置一個預設的limit和offset。

支持的格式

選擇合適的API響應信息的格式是很重要的。大多數現代應用都會使用JSON。你也應該使用JSON,除非你有一些舊時的需求要求你使用XML響應。

回覆合適的錯誤代碼

一個很好的實踐就是保持一個服務錯誤信息的集合併加上合適的ID。比如,如果你使用過FACEBOOK的graph API,當產生錯誤時,它會給你返回:

{
  "error": {
    "message": "(#803) Some of the aliases you requested do not exist: products",
    "type": "OAuthException",
    "code": 803,
    "fbtrace_id": "FOXX2AhLh80"
  }
}

我也見過有些錯誤信息還會告訴用戶如何應對這個錯誤。這也是一個很好的實踐。

使用OPEN API SPECIFICATIONS

如果你也像我一樣希望所有的團隊都遵守統一的規則,你可以使用OPEN API Specification。Open API允許我們在設計好API後更加便捷的分享給客戶或者其他團隊。

總結

顯而易見的,如果你想要更好的和客戶或者其他團隊溝通,API絕對是正確的方式。但如果API沒有被很好的設計,反而會徒增別人(或者也有你自己?)的困惑。所以,請在設計階段放入更多的心思。剩下的只不過就是實現而已了!


 

感謝您的閱讀

如果你對設計API有更好的意見和建議,請在評論區分享出來吧!歡迎任何的反饋和糾錯!謝謝!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 做簡單相冊,點擊小圖片,下麵的圖片進行放大 佈局為上下分別為兩個div 上面一個div內的圖片用a標簽包含 頁面效果為點擊上面div的圖片下麵的圖片換成對應的圖片 js思路為: 首先分別找到上面 <!DOCTYPE html> <html lang="en"> <head> <meta charse ...
  • heigh:100%失效 解決: 1. html, body {height: 100%;} 2. div { height: 100%; position: absolute;} 非定位元素的寬高百分比計算不會將 padding 計算在內,而定位元素會計算在內。 利用這個特性可以實現圖片左右半區點 ...
  • float 特性 包裹性; 塊狀化並格式化上下文; 破壞文檔流,使父元素高度塌陷,在父元素中浮動元素高度不計在內; 沒有任何 margin 合併 使浮動元素後的非浮動元素的文本環繞著浮動元素 浮動之間的排列 元素設為浮動後會變為包裹性,若沒有明確寬度,寬度則是元素里的內容寬度。浮動元素會生成一個塊級 ...
  • GitHub地址: https://github.com/jeromeetienne/jquery-qrcode ...
  • java的(PO,VO,TO,BO,DAO,POJO)解釋 O/R Mapping 是 Object Relational Mapping(對象關係映射)的縮寫。通俗點講,就是將對象與關係資料庫綁定,用對象來表示關係數據。在O/R Mapping的世界里,有兩個基本的也是重要的東東需要瞭解,即VO, ...
  • 載入靜態文件 在一個網頁中,不僅僅只有一個 html 骨架,還需要 css 樣式文件, js 執行文件以及一些圖片 等。因此在 DTL 中載入靜態文件是一個必須要解決的問題。在 DTL 中,使用 static 標簽來載入 靜態文件。要使用 static 標簽,首先需要 {% load static ...
  • 人應該自信點,因為在某個方面,你無人可取代。做事,做人都要有底線,一件事的底線是什麼,做人的底線是什麼,做事的底線要符合做人的底線。這些事都要清楚。 工作要努力,對你最直接的回饋,就是努力工作所應得的報酬。做人要積極上進,(欲望驅使,興趣驅使,職業規劃,人生態度,生活態度驅使等等) 我今年的計劃,是 ...
  • 在使用 RabbitMQ 的時候,作為消息發送方希望杜絕任何消息丟失或者投遞失敗場景。RabbitMQ 為我們提供了兩個選項用來控制消息的投遞可靠性模式。 rabbitmq 整個消息投遞的路徑為: producer->rabbitmq broker cluster->exchange->que... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...