RESTful API 中的 Status code 是否要遵守規(guī)范

緣起

事情是這樣的吨掌,我在知乎受到邀請(qǐng)回答一個(gè)問(wèn)題思犁,主要是問(wèn) ID 找不到到底要不要用 Status 404 激蹲。我回答的還是比較早的棉磨,那時(shí)候只有一兩個(gè)回答。我本來(lái)以為這是沒(méi)啥爭(zhēng)議的策泣,在一個(gè)學(xué)術(shù)的地方討論學(xué)術(shù)問(wèn)題衙傀,當(dāng)然是要遵守規(guī)范了,結(jié)果過(guò)了幾個(gè)小時(shí)大跌眼鏡萨咕。自造 code 黨竟然支持率第一统抬,還好平時(shí)見(jiàn)的也很多的全 200 黨沒(méi)有受到支持,不然真的吐血了。

為什么要遵守規(guī)范

一般那種說(shuō)特殊情況特殊處理聪建,不要拘泥于規(guī)范的人钙畔,大多都是自己沒(méi)搞清楚某些知識(shí),拿這句話當(dāng)作偷懶的借口金麸。其實(shí)一般做項(xiàng)目沒(méi)那么多特殊情況擎析。

為了更好的適應(yīng)各種庫(kù)

大部分完善的 HTTP 請(qǐng)求庫(kù),都會(huì)依照 RFC 的規(guī)范去設(shè)計(jì)錯(cuò)誤處理的流程挥下,雖然處理方式各有不同揍魂,但一定會(huì)在文檔說(shuō)明錯(cuò)誤處理的部分的。使用 RFC 標(biāo)準(zhǔn)能最大限度的兼容各種 HTTP 客戶端棚瘟。你說(shuō)現(xiàn)在你用的HTTP客戶端不處理 Status Code现斋,但是你沒(méi)法保證將來(lái)不重構(gòu),重構(gòu)的時(shí)候還是不處理解取。

一般調(diào)用 api 使用 js 或者 python 的概率比較大步责,我們看看知名的庫(kù)返顺。在 js 里禀苦,最近比較流行的 axios 默認(rèn)會(huì)把 200 系列外的 code 歸到異常里。在 python 里遂鹊,最流行的 http client 是 requests 振乏,它更為詳盡的預(yù)處理了 status code 。

為了開(kāi)發(fā)者更好上手

另外在管理團(tuán)隊(duì)的方面秉扑,我們的原則是盡量的減少一個(gè)項(xiàng)目的“規(guī)范”慧邮,這樣才能更容易去遵守。能用標(biāo)準(zhǔn)的地方舟陆,一定不要自己定一個(gè)更復(fù)雜的規(guī)則误澳。無(wú)論是服務(wù)端的維護(hù)者還是 API 的消費(fèi)者是會(huì)換人流動(dòng)的,每個(gè)進(jìn)入項(xiàng)目的人熟悉一大堆無(wú)謂的自定義項(xiàng)目規(guī)范都要成本秦躯。

更簡(jiǎn)單的辦法是參考大廠

其實(shí)給項(xiàng)目定規(guī)范忆谓,最不靠譜的是自己拍腦袋,稍好一點(diǎn)的是去知乎或論壇問(wèn)踱承,更好一點(diǎn)的是去 google 搜倡缠,最簡(jiǎn)單的是直接去看大廠的產(chǎn)品或者規(guī)范啊。 API 本來(lái)就是個(gè)公開(kāi)暴露的東西茎活,還有比這更好找參考的嗎昙沦?我們來(lái)看看:

  • Google 遵守規(guī)范
  • Github 遵守規(guī)范
  • Microsoft 遵守規(guī)范 順便說(shuō)一句,微軟的 API 規(guī)范真的很具有指導(dǎo)意義载荔。
  • Twitter 遵守規(guī)范
  • 阿里云 遵守規(guī)范
  • 騰訊云 不遵守規(guī)范 全部 200 事實(shí)上騰訊的技術(shù)比較混亂盾饮,每個(gè)項(xiàng)目都不一樣。但最新要執(zhí)行的統(tǒng)一規(guī)范是全部 返回 200 用返回值中的錯(cuò)誤碼表明錯(cuò)誤。
  • 百度云 遵守規(guī)范

我的建議

很多人也許用著很簡(jiǎn)陋的 Web 框架丘损,導(dǎo)致誤以為返回了錯(cuò)誤碼芍碧,就不能返回 Response Body 了。其實(shí)你返回 204 外的任何 Status Code号俐,最好都伴隨著返回 Body 泌豆。

在項(xiàng)目規(guī)范里,可以規(guī)定 Status Code 遵照 RFC 標(biāo)準(zhǔn)吏饿,或者選定一個(gè)集合出來(lái)踪危,把一些不常用的去掉。然后如果不是200系列的代碼猪落,必須伴隨著這樣的一個(gè)錯(cuò)誤結(jié)構(gòu):

{
    "error": "UserNotFound",
    "message": "該用戶沒(méi)有找到"
 }

這樣錯(cuò)誤分為了三層結(jié)構(gòu)贞远,第一層是 Status Code,使用者能大概知道是什么問(wèn)題笨忌。第二層Error 是一個(gè) Key 使用約定好的無(wú)空格的英文蓝仲,給使用者做判斷用,使用者可以根據(jù) Key 自定義接下來(lái)的操作官疲。第三層是 message 袱结,有些 Key 使用者可以決定直接把 Message 顯示個(gè)終端客戶。

如果是微服務(wù)項(xiàng)目途凫,需要要求每個(gè)服務(wù)不管用什么語(yǔ)言垢夹,都要把錯(cuò)誤統(tǒng)一成這個(gè)樣子。如果開(kāi)發(fā)者告訴你框架不支持维费,那這一定不是個(gè)好框架果元,改重構(gòu)了。好的框架不僅能讓你自定義錯(cuò)誤內(nèi)容犀盟,還能做到所謂的“框架自己出錯(cuò)的返回”也由你自定義而晒。比如路由沒(méi)有找到之類的。

最后

我實(shí)在不明白為什么一個(gè)最扯淡的答案阅畴,要自造一個(gè) 600 的 status code 倡怎,可以得票第一。知乎用戶到底有沒(méi)有一點(diǎn)獨(dú)立的判斷精神啊恶阴,只要裝的一本正經(jīng)诈胜,再擺出來(lái)一點(diǎn)資歷,哪怕是胡說(shuō)八道冯事,大家也紛紛點(diǎn)贊焦匈。也許真的不適合在知乎去回答技術(shù)問(wèn)題了。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末昵仅,一起剝皮案震驚了整個(gè)濱河市缓熟,隨后出現(xiàn)的幾起案子累魔,更是在濱河造成了極大的恐慌,老刑警劉巖够滑,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件垦写,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡彰触,警方通過(guò)查閱死者的電腦和手機(jī)梯投,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)况毅,“玉大人分蓖,你說(shuō)我怎么就攤上這事《恚” “怎么了么鹤?”我有些...
    開(kāi)封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)味廊。 經(jīng)常有香客問(wèn)我蒸甜,道長(zhǎng),這世上最難降的妖魔是什么余佛? 我笑而不...
    開(kāi)封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任柠新,我火速辦了婚禮,結(jié)果婚禮上衙熔,老公的妹妹穿的比我還像新娘登颓。我一直安慰自己搅荞,他們只是感情好红氯,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著咕痛,像睡著了一般痢甘。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上茉贡,一...
    開(kāi)封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天塞栅,我揣著相機(jī)與錄音,去河邊找鬼腔丧。 笑死放椰,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的愉粤。 我是一名探鬼主播砾医,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼衣厘!你這毒婦竟也來(lái)了如蚜?” 一聲冷哼從身側(cè)響起压恒,我...
    開(kāi)封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎错邦,沒(méi)想到半個(gè)月后探赫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡撬呢,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年伦吠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片魂拦。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡讨勤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出晨另,到底是詐尸還是另有隱情潭千,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布借尿,位于F島的核電站刨晴,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏路翻。R本人自食惡果不足惜狈癞,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一妄均、第九天 我趴在偏房一處隱蔽的房頂上張望还棱。 院中可真熱鬧,春花似錦爱榔、人聲如沸掉冶。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)厌小。三九已至恢共,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間璧亚,已是汗流浹背讨韭。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留癣蟋,地道東北人透硝。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像疯搅,于是被迫代替她去往敵國(guó)和親濒生。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

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