「譯」 REST 資源命名指南

前言

原文地址:REST Resource Naming Guide數據庫

資源的定義
在 REST 中,主要數據表示爲資源;REST 中信息的關鍵抽象是一種資源; 能夠命名的任何信息均可以是資源:文檔或圖像,臨時服務(例如「洛杉磯的今每天氣」),其餘資源的集合,非虛擬對象(例如人)等等。 換句話說,任何多是做者超文本引用目標的概念都必須符合資源的定義。 資源是對一組實體的概念映射,而不是與任何特定時間點的映射相對應的實體。api

資源能夠是單例或集合。
例如,「customers」是一個集合資源,「customer」是一個單例資源(在銀行領域)。 咱們可使用URI「/ customers」來識別「customers」集合資源。 咱們可使用URI「/ customers / {customerId}」識別單個「客戶」資源。瀏覽器

資源也能夠包含子集合資源。
例如,可使用URN「/ customers / {customerId} / accounts」(在銀行業務域中)來識別特定「客戶」的子收集資源「帳戶」。
相似地,子集合資源「賬戶」內的單個資源「賬戶」能夠標識以下:「/ customers / {customerId} / accounts / {accountId}」。bash

REST API使用統一資源標識符(URI)來定位資源。
REST API設計者應該建立URI,將REST API的資源模型傳達給潛在的客戶端開發人員。 當資源命名良好時,API直觀且易於使用。 若是作得很差,那麼相同的API會感受難以使用和理解。
統一接口的約束部分經過URI和HTTP動詞的組合來解決,而且根據標準和約定使用它們。
如下是爲新API建立資源URI時可使用的一些提示。服務器

使用名詞表示資源

RESTful URI應該引用做爲事物(名詞)的資源而不是引用動做(動詞),由於名詞具備動詞不具備的屬性 - 相似於具備屬性的資源。 資源的一些示例是:
系統的用戶
用戶賬戶
網絡設備等
他們的資源URI能夠設計以下:restful

http://api.example.com/device-management/managed-devices 
http://api.example.com/device-management/managed-devices/{device-id} 
http://api.example.com/user-management/users/
http://api.example.com/user-management/users/{id}
複製代碼

爲了更清楚,讓咱們將資源原型劃分爲四個類別(文檔,集合,存儲和控制器),而後您應始終將資源放入一個原型,而後始終如一地使用它的命名約定。 爲了資源的一致性,請抵制去設計資源的誘惑,這些資源將是不止一個原型的混合體。 網絡

文檔

文檔資源是一種相似於對象實例或數據庫記錄的單一律念。 在REST中,您能夠將其視爲資源集合中的單個資源。 文檔的狀態表示一般包括具備值的字段和指向其餘相關資源的連接。
使用「單數」名稱表示文檔資源原型:ide

http://api.example.com/device-management/managed-devices/{device-id}
http://api.example.com/user-management/users/{id}
http://api.example.com/user-management/users/admin
複製代碼

集合

集合資源是服務器管理的資源目錄。 客戶能夠建議將新資源添加到集合中。 可是,要由集合選擇是否建立新資源。 集合資源選擇它想要包含的內容,並決定每一個包含的資源的URI。
使用「複數」名稱表示集合資源原型:函數

http://api.example.com/device-management/managed-devices
http://api.example.com/user-management/users
http://api.example.com/user-management/users/{id}/accounts
複製代碼

存儲

存儲是客戶端管理的資源庫。 存儲資源容許API客戶端放入資源,將其退出,並決定什麼時候刪除它們。 存儲永遠不會生成新的URI。 相反,每一個存儲的資源都有一個客戶端在最初放入存儲時選擇的URI。
使用「複數」名稱表示存儲資源原型:字體

http://api.example.com/cart-management/users/{id}/carts
http://api.example.com/song-management/users/{id}/playlists
複製代碼

控制器

控制器資源模擬程序概念。 控制器資源就像可執行函數,帶有參數和返回值; 輸入和輸出。
使用「動詞」表示控制器原型:

http://api.example.com/cart-management/users/{id}/cart/checkout
http://api.example.com/song-management/users/{id}/playlist/play
複製代碼

保持一致性

使用一致的資源命名約定和URI格式,以最小化和最大可讀性和可維護性。 您能夠實現如下設計提示以實現一致性:

使用正斜槓(/)表示層次關係

正斜槓(/)字符用於URI的路徑部分,以指示資源之間的層次關係。 例如:

http://api.example.com/device-management
http://api.example.com/device-management/managed-devices
http://api.example.com/device-management/managed-devices/{id}
http://api.example.com/device-management/managed-devices/{id}/scripts
http://api.example.com/device-management/managed-devices/{id}/scripts/{id}
複製代碼

不要在URI中使用尾部正斜槓(/)

做爲URI路徑中的最後一個字符,正斜槓(/)不會添加語義值,並可能致使混淆。 最好徹底放棄它們。

http://api.example.com/device-management/managed-devices/
http://api.example.com/device-management/managed-devices 	/*This is much better version*/
複製代碼

使用連字符( - )來提升URI的可讀性

要使您的URI易於掃描和解釋,請使用連字符( - )字符來提升長路徑段中名稱的可讀性。

http://api.example.com/inventory-management/managed-entities/{id}/install-script-location  //More readable
http://api.example.com/inventory-management/managedEntities/{id}/installScriptLocation  //Less readable
複製代碼

不要使用下劃線(_)

可使用下劃線代替連字符做爲分隔符 - 可是根據應用程序的字體,下劃線()字符可能會在某些瀏覽器或屏幕中被部分遮擋或徹底隱藏。
**爲避免這種混淆,請使用連字符( - )而不是下劃線(
)。**

http://api.example.com/inventory-management/managed-entities/{id}/install-script-location  //More readable
http://api.example.com/inventory_management/managed_entities/{id}/install_script_location  //More error prone
複製代碼

在URI中使用小寫字母

方便時,URI路徑中應始終首選小寫字母。
RFC 3986 將URI定義爲區分大小寫,但方案和主機組件除外。 例如:

http://api.example.org/my-folder/my-doc  //1
HTTP://API.EXAMPLE.ORG/my-folder/my-doc  //2
http://api.example.org/My-Folder/my-doc  //3
複製代碼

在上面的例子中,1和2是相同的,但3不是。由於它使用大寫字母的My-Folder。

不要使用文件擴展名

文件擴展名看起來很糟糕,不會增長任何優點。 刪除它們也會減小URI的長度。 沒理由保留它們。
除了上述緣由,若是您想使用文件擴展突出顯示API的媒體類型,那麼您應該依賴於經過Content-Type標頭傳達的媒體類型來肯定如何處理正文的內容。

http://api.example.com/device-management/managed-devices.xml  /*Do not use it*/
http://api.example.com/device-management/managed-devices 	/*This is correct URI*/
複製代碼

切勿在URI中使用CRUD函數名稱

URI不該用於指示執行CRUD功能。 URI應該用於惟一標識資源,而不是對它們的任何操做。 應使用HTTP請求方法來指示執行哪一個CRUD功能。

HTTP GET http://api.example.com/device-management/managed-devices  //Get all devices
HTTP POST http://api.example.com/device-management/managed-devices  //Create new Device

HTTP GET http://api.example.com/device-management/managed-devices/{id}  //Get device for given Id
HTTP PUT http://api.example.com/device-management/managed-devices/{id}  //Update device for given Id
HTTP DELETE http://api.example.com/device-management/managed-devices/{id}  //Delete device for given Id
複製代碼

使用查詢參數過濾URI集合

不少時候,您會遇到須要根據某些特定資源屬性對須要排序,過濾或限制的資源集合的要求。 爲此,請不要建立新的API  - 而是在資源集合API中啓用排序,過濾和分頁功能,並將輸入參數做爲查詢參數傳遞。 例如:

http://api.example.com/device-management/managed-devices
http://api.example.com/device-management/managed-devices?region=USA
http://api.example.com/device-management/managed-devices?region=USA&brand=XYZ
http://api.example.com/device-management/managed-devices?region=USA&brand=XYZ&sort=installation-date
複製代碼
相關文章
相關標籤/搜索