GET /user/info/1 ID 查詢,如需查詢多個,ID 列表通過 Query 參數傳遞,形如 ids=1,2,3
POST /user/create 創建
POST /user/update/1 更新,只更新傳遞的字段,未傳遞的字段保持不變
POST /user/replace/1 替換,整體更新,未傳遞的字段將清空
POST /user/delete/1 刪除,如需刪除多個,ID 列表通過請求體傳遞,形如 {"ids": [1, 2, 3]}
GET /user/list?gender=male&minAge=18
GET /user/infoByUsername?username=jack
GET /user/follow?followingId=1&followerId=2 涉及到多個 ID 組合才能定位資源時,統一通過 Query 參數傳遞
POST /user/sendVerifyCode

4. API 路徑

對于采用微服務架構的應用,需要通過路徑前綴來區分前后端資源,以及不同的微服務。

5. API 版本

對于內部使用的 API,自己可以控制客戶端升級節奏,應避免使用 API 版本,因為維護多版本 API 的成本很高。對于對外開放的 API,由于無法控制使用方客戶端升級節奏,那么可以通過多版本 API 來實現平滑升級,在廢棄老版 API 之前給使用方留足夠的升級時間。

API 版本號可在不同的層級上添加,以前面的創建用戶 API /api/user/user/create 為例,按作用范圍由大到小有以下幾種方式:

不建議為不同版本的服務啟動不同的實例,隨著版本的不斷升級,后期的維護工作會越來越大。對于同一個服務的不同版本 API,應使用一套代碼,新版 API Controller 可以通過繼承老版 Controller 來盡量復用現有代碼。

6. 請求

公共參數

通過 HTTP 頭來傳遞公共參數,優先使用 HTTP 標準頭,沒有合適的再自定義,自定義 HTTP 頭需以 X- 打頭。

HTTP 頭示例用途
AuthorizationBearer認證服務頒發的 Token
Accept-Languagezh-CN,zh;q=0.9,en-US,en;q=0.1可接受的響應內容語言,優先使用權重高的
X-Client-NameBasicAI客戶端名稱
X-Client-Versionv1.0.0客戶端版本

請求體

示例

{
"username": "jack",
"password": "12345678",
"age": 17
}

7. 響應

響應狀態碼

HTTP 狀態碼設計的初衷是用于靜態資源訪問場景,對于 API 這種動態服務場景,許多狀態碼都不適用,或者根本無法表示各種千奇百怪的業務錯誤。因此這里推薦只使用下面這些少量的 HTTP 狀態碼,其它業務異常情況統一響應 200 狀態碼,并在響應體里通過 code 返回具體的業務錯誤碼。

響應體

響應體為 JSON 對象,結構如下:

{
"code": "OK", // 業務錯誤碼
"message": "", // 業務錯誤描述
"data": null // 業務數據
}

單項業務數據直接通過 data 字段返回示例

{
"code": "OK",
"message": "",
"data": {
"id": 1,
"username": "jack"
}
}

多項業務數據需包一層示例

{
"code": "OK",
"message": "",
"data": {
"user": {
"id": 1,
"username": "jack"
},
"roles": []
}
}

列表數據示例

{
"code": "OK",
"message": "",
"data": {
"list": [],
"total": 1000
}
}

業務出錯示例

{
"code": "BILLING__PAY__MONEY_NOT_ENOUGH",
"message": "money not enough",
"data": null
}

8. 分頁規范

基于頁

適合客戶端有翻頁條,按頁展示數據,數據集變化較慢的場景。

{
"code": "ok",
"message": "",
"data": {
"total": 100,
"pageNo": 1,
"pageSize": 10,
"list": []
}
}

基于偏移量

適合沒有翻頁條的流式加載模式場景,如果起始位置使用主鍵 ID、創建時間這樣的排序字段,服務端可以通過大于或等于比較來加速查詢,并且在數據集有變化時能夠保證分批獲取的數據不重復。

{
"code": "ok",
"message": "",
"data": {
"total": 100,
"offset": 0,
"limit": 10,
"list": []
}
}

五、案例分析

假設我們正在設計一個電商平臺的微服務架構,其中包括用戶服務、訂單服務和支付服務。每個服務都有自己的 API,這些 API 通過 RESTful 設計原則進行設計,并實現了 OAuth 2.0 身份認證。我們為每個服務提供了詳細的 Swagger 文檔,并在持續集成過程中運行自動化測試,以確保各個服務間的交互順暢。

用戶服務

POST /api/user/user/create
Content-Type: application/json

{
"username": "jack",
"password": "12345678",
"age": 17
}
GET /api/user/user/info/1

訂單服務

POST /api/order/order/create
Content-Type: application/json

{
"userId": 1,
"items": [
{
"itemId": 101,
"quantity": 2
},
{
"itemId": 102,
"quantity": 1
}
]
}
GET /api/order/order/list?userId=1

支付服務

POST /api/payment/payment/create
Content-Type: application/json

{
"orderId": 1,
"amount": 100
}
GET /api/payment/payment/status/1

六、總結

微服務架構下的 API 設計需要綜合考慮資源管理、版本控制、安全性、錯誤處理以及文檔和測試等多個方面。通過遵循這些最佳實踐,我們可以構建出高效、可靠的 API,從而支持系統的可擴展性和靈活性。希望本文對您有所幫助,并為您的微服務架構設計提供了一些有價值的信息和見解。

熱門推薦
一個賬號試用1000+ API
助力AI無縫鏈接物理世界 · 無需多次注冊
3000+提示詞助力AI大模型
和專業工程師共享工作效率翻倍的秘密
返回頂部
上一篇
API網關的作用是什么:從功能到性能的全方位解析
下一篇
企業微信 API:實現高效企業協作與管理
国内精品久久久久影院日本,日本中文字幕视频,99久久精品99999久久,又粗又大又黄又硬又爽毛片
国产一区二区在线免费观看| 91啪在线观看| 国产亚洲人成网站| 日本成人在线看| 色婷婷综合久久久久中文一区二区 | 色哦色哦哦色天天综合| 欧美精选一区二区| 三级影片在线观看欧美日韩一区二区 | 欧美日韩国产综合久久| 亚洲午夜电影在线观看| 国产一区二区三区在线看麻豆| 美女精品一区二区| 久久免费午夜影院| caoporm超碰国产精品| 亚洲精品中文在线| 欧美大片一区二区| 色婷婷久久久久swag精品| 欧美人xxxx| 成人av在线资源| 亚洲综合偷拍欧美一区色| 欧美成人猛片aaaaaaa| 一区二区三区欧美| 国产女同互慰高潮91漫画| 成人国产在线观看| 国产日韩欧美亚洲| 欧美极品xxx| 欧美成人精品1314www| 亚洲成av人片一区二区梦乃| 一本久久综合亚洲鲁鲁五月天| 国产乱码精品1区2区3区| 久久99国内精品| 成人国产精品免费观看| 亚洲男人的天堂在线观看| 日本道色综合久久| zzijzzij亚洲日本少妇熟睡| 亚洲国产美女搞黄色| 欧美日精品一区视频| 欧美乱妇23p| 欧美日韩中文另类| 久久久久久亚洲综合影院红桃| 欧美日本一道本| 色欧美乱欧美15图片| 色综合天天性综合| 一区二区三区视频在线看| 久久久久国色av免费看影院| 久久综合五月天婷婷伊人| 91浏览器打开| 欧美日韩国产乱码电影| 亚洲精品成a人| 亚洲电影你懂得| 青青草伊人久久| 欧美美女喷水视频| 91福利在线看| 欧美视频在线不卡| 成人国产精品免费观看视频| 色综合天天在线| 国产欧美日韩精品一区| 一区二区三区蜜桃网| 久久国产尿小便嘘嘘尿| 91玉足脚交白嫩脚丫在线播放| 欧美在线观看一二区| 国产日韩欧美精品在线| 国产精品福利一区二区三区| 九九**精品视频免费播放| 色一情一乱一乱一91av| 蜜臀精品一区二区三区在线观看| 精品粉嫩aⅴ一区二区三区四区| 国产精品久久久久久久蜜臀| 欧美电视剧免费全集观看| 日本强好片久久久久久aaa| 国产成人av资源| 国产高清不卡一区二区| 99久久婷婷国产综合精品电影| 日韩一区二区在线看| 天天综合色天天综合| 日韩电影在线观看一区| 久久婷婷国产综合精品青草| 国产精品一区免费视频| 精品sm捆绑视频| 爽好多水快深点欧美视频| 91精品国产乱码| 国产69精品久久99不卡| 亚洲一区日韩精品中文字幕| 欧美一区二区日韩一区二区| 国产精品18久久久久久久网站| 久久先锋影音av鲁色资源| 欧美一区中文字幕| 亚洲第一福利一区| 欧美一区二区三区四区五区| 国产999精品久久久久久绿帽| 久久噜噜亚洲综合| 欧美日韩综合在线| 欧美肥大bbwbbw高潮| 激情综合网最新| 日韩精品一区二区三区老鸭窝| 亚洲精品国产高清久久伦理二区| 欧美成人艳星乳罩| 国产精品综合网| 久久综合色综合88| 精品久久久久久久久久久久久久久久久 | 亚洲视频免费观看| 欧美一级高清片在线观看| 在线日韩av片| 欧美精品一级二级| 在线不卡欧美精品一区二区三区| 成人免费av在线| 亚洲成a人v欧美综合天堂下载 | 中文字幕国产精品一区二区| 国产亲近乱来精品视频| 69堂国产成人免费视频| 日韩一区二区中文字幕| 国产欧美一区二区在线观看| 一区二区三区在线高清| 欧美一级二级三级乱码| 678五月天丁香亚洲综合网| 国产99久久久国产精品潘金| 在线观看日韩精品| 亚洲视频免费在线| 国产网红主播福利一区二区| 亚洲无人区一区| 丁香一区二区三区| 欧美精品一区二区三区四区 | 久久精品日韩一区二区三区| 中文字幕一区二区三区在线不卡| 欧美老肥妇做.爰bbww| 日韩毛片在线免费观看| 成人做爰69片免费看网站| 国产校园另类小说区| 国产高清在线观看免费不卡| 久久中文娱乐网| 国产精品亚洲一区二区三区在线| 久久这里只精品最新地址| 高清av一区二区| 亚洲一区二区三区美女| 51精品国自产在线| 亚洲国产高清在线| 在线观看精品一区| 美女视频第一区二区三区免费观看网站| 欧美日韩国产成人在线免费| 激情文学综合网| 亚洲精品伦理在线| 91视频www| 色诱亚洲精品久久久久久| 99麻豆久久久国产精品免费 | 中文字幕av不卡| 午夜免费久久看| 狠狠色狠狠色综合系列| 国产在线精品一区二区不卡了| 亚洲高清不卡在线观看| 99久久国产综合精品麻豆| 久久―日本道色综合久久| 欧美一区二区三区视频在线| 91行情网站电视在线观看高清版| 亚洲美女免费在线| 日韩av成人高清| 国产999精品久久久久久| 欧美日韩精品二区第二页| 亚洲欧美色一区| 欧美自拍偷拍一区| 麻豆精品国产传媒mv男同 | 国产成人精品影视| 国产高清无密码一区二区三区| 国产精品二三区| 欧美成人aa大片| 56国语精品自产拍在线观看| 精品国产免费人成电影在线观看四季| 日韩av午夜在线观看| 午夜精品久久久久久久久久久| 中文字幕不卡在线观看| 国产精品久久一卡二卡| 成人av综合在线| 日韩视频在线你懂得| 欧美另类变人与禽xxxxx| 91精品国产品国语在线不卡 | 日韩欧美国产三级电影视频| 国产欧美一区二区精品仙草咪| 一区二区三区蜜桃| 精品一区二区三区在线观看| 激情综合网av| 国产mv日韩mv欧美| 欧美伦理电影网| 亚洲精选免费视频| 中文字幕亚洲一区二区va在线| 久久亚洲二区三区| 偷拍亚洲欧洲综合| 91亚洲精品久久久蜜桃网站| 精品不卡在线视频| 国产精品一区二区久久不卡| 99久久久久久| 亚洲三级免费观看| 午夜免费久久看| 欧美一级高清大全免费观看| 亚洲一区二区免费视频| 日韩亚洲欧美综合| 国产在线精品一区二区夜色 | 奇米影视一区二区三区小说| 国产亚洲精品中文字幕| 国内精品在线播放| 久久久精品免费网站| av成人免费在线观看|