API設(shè)計(jì)規(guī)范

API設(shè)計(jì)規(guī)范(RESTful)

一烤芦、協(xié)議

采用HTTPs

二胁编、域名

https:// example.org/api/

三呻惕、版本

將版本號放在HTTP頭信息里面

四酷鸦、路徑

路徑又稱"終點(diǎn)"(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è)計(jì)成下面這樣删咱。

https://api.example.com/zoos

https://api.example.com/animals

https://api.example.com/employees

五、HTTP動詞

對于資源的具體操作類型豪筝,由HTTP動詞表示痰滋。

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

GET(SELECT):從服務(wù)器取出資源(一項(xiàng)或多項(xiàng))续崖。

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:刪除某個指定動物園的指定動物

六奸披、過濾信息

如果記錄數(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è)計(jì)允許存在冗余,即允許API路徑和URL參數(shù)偶爾有重復(fù)箕母。比如储藐,GET /zoo/ID/animals 與 GET / animals?zoo_id=ID 的含義是相同的。

七嘶是、狀態(tài)碼

服務(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)入后臺排隊(duì)(異步任務(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ā)生一個驗(yàn)證錯誤继准。

500 INTERNAL SERVER ERROR - [*]:服務(wù)器發(fā)生錯誤,用戶將無法判斷發(fā)出的請求是否成功矮男。

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

八、錯誤處理

如果狀態(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:返回一個空文檔

十崎弃、其他

服務(wù)器返回的數(shù)據(jù)格式甘晤,使用JSON

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市饲做,隨后出現(xiàn)的幾起案子线婚,更是在濱河造成了極大的恐慌,老刑警劉巖盆均,帶你破解...
    沈念sama閱讀 221,548評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件塞弊,死亡現(xiàn)場離奇詭異,居然都是意外死亡泪姨,警方通過查閱死者的電腦和手機(jī)游沿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,497評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來肮砾,“玉大人诀黍,你說我怎么就攤上這事≌檀Γ” “怎么了眯勾?”我有些...
    開封第一講書人閱讀 167,990評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長婆誓。 經(jīng)常有香客問我吃环,道長,這世上最難降的妖魔是什么洋幻? 我笑而不...
    開封第一講書人閱讀 59,618評論 1 296
  • 正文 為了忘掉前任郁轻,我火速辦了婚禮,結(jié)果婚禮上文留,老公的妹妹穿的比我還像新娘范咨。我一直安慰自己故觅,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,618評論 6 397
  • 文/花漫 我一把揭開白布渠啊。 她就那樣靜靜地躺著输吏,像睡著了一般。 火紅的嫁衣襯著肌膚如雪替蛉。 梳的紋絲不亂的頭發(fā)上贯溅,一...
    開封第一講書人閱讀 52,246評論 1 308
  • 那天,我揣著相機(jī)與錄音躲查,去河邊找鬼它浅。 笑死,一個胖子當(dāng)著我的面吹牛镣煮,可吹牛的內(nèi)容都是我干的姐霍。 我是一名探鬼主播,決...
    沈念sama閱讀 40,819評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼典唇,長吁一口氣:“原來是場噩夢啊……” “哼镊折!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起介衔,我...
    開封第一講書人閱讀 39,725評論 0 276
  • 序言:老撾萬榮一對情侶失蹤恨胚,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后炎咖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體赃泡,經(jīng)...
    沈念sama閱讀 46,268評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,356評論 3 340
  • 正文 我和宋清朗相戀三年乘盼,在試婚紗的時候發(fā)現(xiàn)自己被綠了升熊。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,488評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡绸栅,死狀恐怖僚碎,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情阴幌,我是刑警寧澤勺阐,帶...
    沈念sama閱讀 36,181評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站矛双,受9級特大地震影響渊抽,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜议忽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,862評論 3 333
  • 文/蒙蒙 一懒闷、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦愤估、人聲如沸帮辟。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,331評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽由驹。三九已至,卻和暖如春昔园,著一層夾襖步出監(jiān)牢的瞬間蔓榄,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,445評論 1 272
  • 我被黑心中介騙來泰國打工默刚, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留甥郑,地道東北人。 一個月前我還...
    沈念sama閱讀 48,897評論 3 376
  • 正文 我出身青樓荤西,卻偏偏與公主長得像澜搅,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子邪锌,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,500評論 2 359

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

  • 前言:如果你有更好的私藏文章勉躺,不凡分享出來,獨(dú)樂樂不如眾樂樂(⊙o⊙) 本文總結(jié)了 RESTful API 設(shè)計(jì)相...
    utopia84閱讀 4,029評論 2 35
  • 前言 網(wǎng)絡(luò)應(yīng)用程序秃流,分為前端和后端兩個部分赂蕴。當(dāng)前的發(fā)展趨勢柳弄,就是前端設(shè)備層出不窮(手機(jī)舶胀、平板、桌面電腦碧注、其他專用設(shè)...
    小白frankie閱讀 438評論 0 1
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理嚣伐,服務(wù)發(fā)現(xiàn),斷路器萍丐,智...
    卡卡羅2017閱讀 134,696評論 18 139
  • API定義規(guī)范 本規(guī)范設(shè)計(jì)基于如下使用場景: 請求頻率不是非常高:如果產(chǎn)品的使用周期內(nèi)請求頻率非常高轩端,建議使用雙通...
    有涯逐無涯閱讀 2,557評論 0 6
  • 譯者:知秋(極樂科技專欄作者)來源:https://zhuanlan.zhihu.com/p/24592119 當(dāng)...
    極樂君閱讀 1,203評論 0 14