RESTful API 設(shè)計指南

RESTful API 設(shè)計指南

轉(zhuǎn)載:http://www.ruanyifeng.com/blog/2014/05/restful_api.html

[TOC]

網(wǎng)絡(luò)應(yīng)用程序耸峭,分為前端和后端兩個部分恋博。當(dāng)前的發(fā)展趨勢今魔,就是前端設(shè)備層出不窮(手機(jī)玄组、平板、桌面電腦胧辽、其他專用設(shè)備......)峻仇。

因此,必須有一種統(tǒng)一的機(jī)制邑商,方便不同的前端設(shè)備與后端進(jìn)行通信摄咆。這導(dǎo)致API構(gòu)架的流行,甚至出現(xiàn)"API First"的設(shè)計思想人断。RESTful API是目前比較成熟的一套互聯(lián)網(wǎng)應(yīng)用程序的API設(shè)計理論吭从。關(guān)于RESTFUL請看這里《理解RESTful架構(gòu)》探討如何理解這個概念。

今天恶迈,將介紹RESTful API的設(shè)計細(xì)節(jié)涩金,探討如何設(shè)計一套合理、好用的API暇仲。主要參考了兩篇文章(1步做,2)。

RESTful API

一奈附、協(xié)議

API與用戶的通信協(xié)議辆床,總是使用HTTPs協(xié)議

二桅狠、域名

應(yīng)該盡量將API部署在專用域名之下。

https://api.example.com

如果確定API很簡單,不會有進(jìn)一步擴(kuò)展中跌,可以考慮放在主域名下咨堤。

https://example.org/api/

三、版本(Versioning)

應(yīng)該將API的版本號放入URL漩符。

https://api.example.com/v1/

另一種做法是一喘,將版本號放在HTTP頭信息中,但不如放入URL方便和直觀嗜暴。Github采用這種做法凸克。

四、路徑(Endpoint)

路徑又稱"終點"(endpoint)闷沥,表示API的具體網(wǎng)址萎战。

在RESTful架構(gòu)中,每個網(wǎng)址代表一種資源(resource)舆逃,所以網(wǎng)址中不能有動詞蚂维,只能有名詞,而且所用的名詞往往與數(shù)據(jù)庫的表格名對應(yīng)路狮。一般來說虫啥,數(shù)據(jù)庫中的表都是同種記錄的"集合"(collection),所以API中的名詞也應(yīng)該使用復(fù)數(shù)奄妨。

舉例來說涂籽,有一個API提供動物園(zoo)的信息,還包括各種動物和雇員的信息砸抛,則它的路徑應(yīng)該設(shè)計成下面這樣评雌。

五、HTTP動詞

對于資源的具體操作類型锰悼,由HTTP動詞表示柳骄。

常用的HTTP動詞有下面五個(括號里是對應(yīng)的SQL命令)。

  • GET(SELECT):從服務(wù)器取出資源(一項或多項)箕般。
  • POST(CREATE):在服務(wù)器新建一個資源耐薯。
  • PUT(UPDATE):在服務(wù)器更新資源(客戶端提供改變后的完整資源)。
  • PATCH(UPDATE):在服務(wù)器更新資源(客戶端提供改變的屬性)丝里。
  • DELETE(DELETE):從服務(wù)器刪除資源曲初。

還有兩個不常用的HTTP動詞。

  • HEAD:獲取資源的元數(shù)據(jù)杯聚。
  • OPTIONS:獲取信息臼婆,關(guān)于資源的哪些屬性是客戶端可以改變的。

下面是一些例子幌绍。

  • GET /zoos:列出所有動物園
  • POST /zoos:新建一個動物園
  • GET /zoos/ID:獲取某個指定動物園的信息
  • PUT /zoos/ID:更新某個指定動物園的信息(提供該動物園的全部信息)
  • PATCH /zoos/ID:更新某個指定動物園的信息(提供該動物園的部分信息)
  • DELETE /zoos/ID:刪除某個動物園
  • GET /zoos/ID/animals:列出某個指定動物園的所有動物
  • DELETE /zoos/ID/animals/ID:刪除某個指定動物園的指定動物

六颁褂、過濾信息(Filtering)

如果記錄數(shù)量很多故响,服務(wù)器不可能都將它們返回給用戶。API應(yīng)該提供參數(shù)颁独,過濾返回結(jié)果彩届。

下面是一些常見的參數(shù)。

  • ?limit=10:指定返回記錄的數(shù)量
  • ?offset=10:指定返回記錄的開始位置誓酒。
  • ?page=2&per_page=100:指定第幾頁樟蠕,以及每頁的記錄數(shù)。
  • ?sortby=name&order=asc:指定返回結(jié)果按照哪個屬性排序靠柑,以及排序順序寨辩。
  • ?animal_type_id=1:指定篩選條件

參數(shù)的設(shè)計允許存在冗余,即允許API路徑和URL參數(shù)偶爾有重復(fù)歼冰。比如靡狞,GET /zoo/ID/animals 與 GET /animals?zoo_id=ID 的含義是相同的。

七停巷、狀態(tài)碼(Status Codes)

服務(wù)器向用戶返回的狀態(tài)碼和提示信息耍攘,常見的有以下一些(方括號中是該狀態(tài)碼對應(yīng)的HTTP動詞)。

  • 200 OK - [GET]:服務(wù)器成功返回用戶請求的數(shù)據(jù)畔勤,該操作是冪等的(Idempotent)蕾各。
  • 201 CREATED - [POST/PUT/PATCH]:用戶新建或修改數(shù)據(jù)成功。
  • 202 Accepted - [*]:表示一個請求已經(jīng)進(jìn)入后臺排隊(異步任務(wù))
  • 204 NO CONTENT - [DELETE]:用戶刪除數(shù)據(jù)成功庆揪。
  • 400 INVALID REQUEST - [POST/PUT/PATCH]:用戶發(fā)出的請求有錯誤式曲,服務(wù)器沒有進(jìn)行新建或修改數(shù)據(jù)的操作,該操作是冪等的缸榛。
  • 401 Unauthorized - [*]:表示用戶沒有權(quán)限(令牌吝羞、用戶名、密碼錯誤)内颗。
  • 403 Forbidden - [*] 表示用戶得到授權(quán)(與401錯誤相對)钧排,但是訪問是被禁止的。
  • 404 NOT FOUND - [*]:用戶發(fā)出的請求針對的是不存在的記錄均澳,服務(wù)器沒有進(jìn)行操作恨溜,該操作是冪等的。
  • 406 Not Acceptable - [GET]:用戶請求的格式不可得(比如用戶請求JSON格式找前,但是只有XML格式)糟袁。
  • 410 Gone -[GET]:用戶請求的資源被永久刪除,且不會再得到的躺盛。
  • 422 Unprocesable entity - [POST/PUT/PATCH] 當(dāng)創(chuàng)建一個對象時项戴,發(fā)生一個驗證錯誤。
  • 500 INTERNAL SERVER ERROR - [*]:服務(wù)器發(fā)生錯誤槽惫,用戶將無法判斷發(fā)出的請求是否成功周叮。

狀態(tài)碼的完全列表參見這里辩撑。

八、錯誤處理(Error handling)

如果狀態(tài)碼是4xx则吟,就應(yīng)該向用戶返回出錯信息槐臀。一般來說,返回的信息中將error作為鍵名氓仲,出錯信息作為鍵值即可。

{
    error: "Invalid API key"
}

九得糜、返回結(jié)果

針對不同操作敬扛,服務(wù)器向用戶返回的結(jié)果應(yīng)該符合以下規(guī)范。

  • GET /collection:返回資源對象的列表(數(shù)組)
  • GET /collection/resource:返回單個資源對象
  • POST /collection:返回新生成的資源對象
  • PUT /collection/resource:返回完整的資源對象
  • PATCH /collection/resource:返回完整的資源對象
  • DELETE /collection/resource:返回一個空文檔

十朝抖、Hypermedia API

RESTful API最好做到Hypermedia啥箭,即返回結(jié)果中提供鏈接,連向其他API方法治宣,使得用戶不查文檔急侥,也知道下一步應(yīng)該做什么。

比如侮邀,當(dāng)用戶向api.example.com的根目錄發(fā)出請求坏怪,會得到這樣一個文檔。

{"link": {
  "rel":   "collection https://www.example.com/zoos",
  "href":  "https://api.example.com/zoos",
  "title": "List of zoos",
  "type":  "application/vnd.yourformat+json"
}}

上面代碼表示绊茧,文檔中有一個link屬性铝宵,用戶讀取這個屬性就知道下一步該調(diào)用什么API了。rel表示這個API與當(dāng)前網(wǎng)址的關(guān)系(collection關(guān)系华畏,并給出該collection的網(wǎng)址)鹏秋,href表示API的路徑,title表示API的標(biāo)題亡笑,type表示返回類型侣夷。

Hypermedia API的設(shè)計被稱為HATEOAS。Github的API就是這種設(shè)計仑乌,訪問api.github.com會得到一個所有可用API的網(wǎng)址列表百拓。

{
  "current_user_url": "https://api.github.com/user",
  "authorizations_url": "https://api.github.com/authorizations",
  // ...
}

從上面可以看到,如果想獲取當(dāng)前用戶的信息绝骚,應(yīng)該去訪問api.github.com/user耐版,然后就得到了下面結(jié)果。

{
  "message": "Requires authentication",
  "documentation_url": "https://developer.github.com/v3"
}

上面代碼表示压汪,服務(wù)器給出了提示信息粪牲,以及文檔的網(wǎng)址。

十一止剖、其他

(1)API的身份認(rèn)證應(yīng)該使用OAuth 2.0框架腺阳。

(2)服務(wù)器返回的數(shù)據(jù)格式落君,應(yīng)該盡量使用JSON,避免使用XML亭引。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末绎速,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子焙蚓,更是在濱河造成了極大的恐慌纹冤,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件购公,死亡現(xiàn)場離奇詭異萌京,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)宏浩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進(jìn)店門知残,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人比庄,你說我怎么就攤上這事求妹。” “怎么了佳窑?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵制恍,是天一觀的道長。 經(jīng)常有香客問我华嘹,道長吧趣,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任耙厚,我火速辦了婚禮强挫,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘薛躬。我一直安慰自己俯渤,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布型宝。 她就那樣靜靜地躺著八匠,像睡著了一般。 火紅的嫁衣襯著肌膚如雪趴酣。 梳的紋絲不亂的頭發(fā)上梨树,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天,我揣著相機(jī)與錄音岖寞,去河邊找鬼抡四。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的指巡。 我是一名探鬼主播淑履,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼藻雪!你這毒婦竟也來了秘噪?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤勉耀,失蹤者是張志新(化名)和其女友劉穎指煎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體便斥,經(jīng)...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡贯要,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了椭住。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡字逗,死狀恐怖京郑,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情葫掉,我是刑警寧澤些举,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站俭厚,受9級特大地震影響户魏,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜挪挤,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一叼丑、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧扛门,春花似錦鸠信、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至葬凳,卻和暖如春绰垂,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背火焰。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工劲装, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人荐健。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓酱畅,卻偏偏與公主長得像琳袄,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子纺酸,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,792評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 網(wǎng)絡(luò)應(yīng)用程序窖逗,分為前端和后端兩個部分。當(dāng)前的發(fā)展趨勢餐蔬,就是前端設(shè)備層出不窮(手機(jī)碎紊、平板、桌面電腦樊诺、其他專用設(shè)備.....
    牛馬風(fēng)情閱讀 173評論 0 2
  • 網(wǎng)絡(luò)應(yīng)用程序仗考,分為前端和后端兩個部分。當(dāng)前的發(fā)展趨勢词爬,就是前端設(shè)備層出不窮(手機(jī)秃嗜、平板、桌面電腦顿膨、其他專用設(shè)備.....
    caikunhai閱讀 247評論 0 0
  • 網(wǎng)絡(luò)應(yīng)用程序锅锨,分為前端和后端兩個部分。當(dāng)前的發(fā)展趨勢恋沃,就是前端設(shè)備層出不窮(手機(jī)必搞、平板、桌面電腦囊咏、其他專用設(shè)備.....
    夕望有你閱讀 370評論 0 0
  • 宿舍有位小姑娘梅割,平常很少回家霜第。有一次快過中秋節(jié)了,她又不想回去了炮捧,我很納悶庶诡,為何放假不回家過節(jié)呢。 她說:“想到回...
    慵懶的小柒閱讀 838評論 18 32
  • 叮鈴鈴咆课,叮鈴鈴末誓,五點二十的鬧鐘想起,伸手按了书蚪,繼續(xù)睡喇澡,叮鈴鈴,五點三十五殊校,按了晴玖,繼續(xù)睡,叮鈴鈴,五點四十呕屎,必須...
    軒姐兒閱讀 133評論 0 0