API 規(guī)范

基本規(guī)范

協(xié)議:https
通信數(shù)據(jù)格式:JSON

命名規(guī)范:

  1. 接口命名:統(tǒng)一使用小寫字母加“-”钞楼,如add-service
  2. 接口參數(shù)命名:統(tǒng)一使用小寫字母 + '_'下劃線分隔,如:user_id

返回格式:{"code" : 200, "message" : "success", "data" : {}}

返回狀態(tài)碼:

  1. 協(xié)議級(jí)(如:200席噩、301匾浪、302、401、403桌肴、502)
  2. 系統(tǒng)級(jí)(如:10001、10002)
  3. 業(yè)務(wù)級(jí)(如:20001琉历、30001坠七、50001)
  4. 異常級(jí)(如:40001)

標(biāo)準(zhǔn)請(qǐng)求:

  • GET(SELECT):從服務(wù)器取出資源(一項(xiàng)或多項(xiàng))
  • POST(CREATE):在服務(wù)器新建一個(gè)資源
  • PUT(UPDATE):在服務(wù)器更新資源(客戶端提供完整資源數(shù)據(jù))
  • PATCH(UPDATE):在服務(wù)器更新資源(客戶端提供需要修改的資源數(shù)據(jù))
  • DELETE(DELETE):從服務(wù)器刪除資源

RESTful API 中的 url 是指向資源的水醋,而不是描述行為的,因此設(shè)計(jì) API 時(shí)彪置,應(yīng)使用名詞而非動(dòng)詞來描述語義拄踪。

備注:不強(qiáng)制要求

代碼實(shí)現(xiàn):

  • GET 請(qǐng)求
    ? 公開的查詢接口(無需鑒權(quán))
  • POST 請(qǐng)求
    ? 增刪改接口
    ? 私密的查詢接口(需要鑒權(quán))

備注:通過修改路由規(guī)則實(shí)現(xiàn) Restful 標(biāo)準(zhǔn)規(guī)范

API URL 示例

api/名詞/
api/名詞/動(dòng)詞/
api/名詞/名詞-動(dòng)詞/

/api/book/list
/api/book/get
/api/book/update

API 動(dòng)詞示例

參考阿里開放平臺(tái) api 接口文檔

create     // 添加
delete     // 刪除
update     // 更新
get        // 獲取
list       // 列表
count      // 統(tǒng)計(jì)
batch      // 批量

search     // 搜索
query      // 查詢

apply      // 申請(qǐng)
confirm    // 確認(rèn)
check      // 檢查
verify     // 驗(yàn)證
change     // 更改

fetch      // 拉取
push       // 推送
send       // 發(fā)送
notify     // 通知
sync       // 同步

bind       // 綁定
unbind     // 解綁

open       // 開啟
close      // 關(guān)閉
cancel     // 取消
done       // 結(jié)束

upload     // 上傳

accept     // 同意
reply      // 回復(fù)
refresh    // 刷新(例如:token)

API 參數(shù)

小寫加下劃線

/api/wordbook/list?page=1&page_size=20

API 返回 Json 串

正確:

{"code" : 200, "message" : "success", "data" : {}}

{
    "code":200,
    "message":"success",
    "data":{
        "items":[
            {
                "id":1,
                "name":"xxx"
            },
            {
                "id":2,
                "name":"xxx"
            }
        ]
    }
}

錯(cuò)誤:

{"code" : 404, "message" : "Page not found", "data" : {}}

{"code" : 500, "message" : "Sth. worng", "data" : {}}

{"status" : 10001, "message" : "Id is empty", "data" : {}}

錯(cuò)誤碼:

40x:HTTP 請(qǐng)求錯(cuò)誤
50x:服務(wù)器錯(cuò)誤
1000x:系統(tǒng)錯(cuò)誤
4000x:異常錯(cuò)誤
(2|3|[5-9])000x:業(yè)務(wù)錯(cuò)誤

HTTP 狀態(tài)碼:

200 SUCCESS - GET 獲取資源
201 CREATED - POST 創(chuàng)建數(shù)據(jù)成功時(shí)
204 No Content - 對(duì)不會(huì)返回響應(yīng)體的成功請(qǐng)求進(jìn)行響應(yīng)(比如DELETE請(qǐng)求)
301 Moved Permanently - 請(qǐng)求的資源已永久移動(dòng)到新位置
302 Move temporarily - 臨時(shí)重定向
304 Not Modified - 文檔的內(nèi)容并未改變,禁止包含消息體
400 Bad Request - 請(qǐng)求異常拳魁,比如請(qǐng)求中的 body 無法解析
401 Unauthorized - 沒有進(jìn)行認(rèn)證或者認(rèn)證非法
403 Forbidden - 當(dāng)認(rèn)證成功惶桐,但是認(rèn)證過的用戶沒有訪問資源的權(quán)限
404 Not Found - 當(dāng)一個(gè)不存在的資源被請(qǐng)求
405 Method Not Allowed - 所請(qǐng)求的HTTP方法不允許當(dāng)前認(rèn)證用戶訪問
410 Gone - 表示當(dāng)前請(qǐng)求的資源不再可用,當(dāng)調(diào)用老版本API的時(shí)候很有用
415 Unsupported Media Type - 如果請(qǐng)求中的內(nèi)容類型是錯(cuò)誤的
422 Unprocessable Entity - 用來表示校驗(yàn)錯(cuò)誤
429 Too Many Requests - 由于請(qǐng)求頻次達(dá)到上限而被拒絕訪問
500 Internal Server Error - 服務(wù)器遇到了一個(gè)未曾預(yù)料的狀況
502 Bad Gateway - 網(wǎng)關(guān)或者代理出錯(cuò)
503 Service Unavailable - 服務(wù)器臨時(shí)維護(hù)或者過載潘懊,服務(wù)器當(dāng)前無法處理請(qǐng)求
504 Gateway Timeout - 請(qǐng)求超時(shí)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末姚糊,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子授舟,更是在濱河造成了極大的恐慌救恨,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件释树,死亡現(xiàn)場離奇詭異忿薇,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)躏哩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門署浩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人扫尺,你說我怎么就攤上這事筋栋。” “怎么了正驻?”我有些...
    開封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵弊攘,是天一觀的道長。 經(jīng)常有香客問我姑曙,道長襟交,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任伤靠,我火速辦了婚禮捣域,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘宴合。我一直安慰自己焕梅,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開白布卦洽。 她就那樣靜靜地躺著贞言,像睡著了一般。 火紅的嫁衣襯著肌膚如雪阀蒂。 梳的紋絲不亂的頭發(fā)上该窗,一...
    開封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天弟蚀,我揣著相機(jī)與錄音,去河邊找鬼酗失。 笑死义钉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的级零。 我是一名探鬼主播断医,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼滞乙,長吁一口氣:“原來是場噩夢啊……” “哼奏纪!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起斩启,我...
    開封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤序调,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后兔簇,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體发绢,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年垄琐,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了边酒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡狸窘,死狀恐怖墩朦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情翻擒,我是刑警寧澤氓涣,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站陋气,受9級(jí)特大地震影響劳吠,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜巩趁,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一痒玩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧议慰,春花似錦凰荚、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至番川,卻和暖如春到涂,著一層夾襖步出監(jiān)牢的瞬間脊框,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來泰國打工践啄, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留浇雹,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓屿讽,卻偏偏與公主長得像昭灵,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子伐谈,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

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

  • 去年有段時(shí)間得空烂完,就把谷歌GAE的API權(quán)威指南看了一遍,收獲頗豐诵棵,特別是在自己幾乎獨(dú)立開發(fā)了公司的云數(shù)據(jù)中心之后...
    騎單車的勛爵閱讀 20,537評(píng)論 0 41
  • 初嘗RESTFul規(guī)范 RESTFul是一種HTTP API接口規(guī)范履澳,只要滿足的RESTFul規(guī)范嘶窄,即可稱為RES...
    izhouteng閱讀 4,002評(píng)論 0 1
  • Restful API規(guī)范 restful api是用于在前端與后臺(tái)進(jìn)行通信的一套規(guī)范。使用這個(gè)規(guī)范可以讓前后端開...
    yungege閱讀 177評(píng)論 1 0
  • 1距贷、服務(wù)必須有完整描述每一個(gè)服務(wù)都必須定義完整如下信息: 服務(wù)中文名服務(wù)中文描述服務(wù)聯(lián)系人姓名服務(wù)聯(lián)系人郵箱正例:...
    Abby_3b3a閱讀 445評(píng)論 0 1
  • restful api是用于在前端與后臺(tái)進(jìn)行通信的一套規(guī)范柄冲。使用這個(gè)規(guī)范可以讓前后端開發(fā)變得更加輕松。以下將討論這...
    97833632c0c7閱讀 1,099評(píng)論 0 0