[點晴永久免費OA]RESTful API設計規范
當前位置:點晴教程→點晴OA辦公管理信息系統
→『 經驗分享&問題答疑 』
該倉庫整理了目前比較流行的 Table of Contents
關于「能愿動詞」的使用為了避免歧義,文檔大量使用了「能愿動詞」,對應的解釋如下:
參見:RFC 2119 Protocol客戶端在通過 API Root URL
如果你的應用很龐大或者你預計它將會變的很龐大,那 Versioning所有的 目前比較常見的兩種版本號形式: 在 URL 中嵌入版本編號api.example.com/v1/* 這種做法是版本號直觀、易于調試;另一種做法是,將版本號放在 通過媒體類型來指定版本信息Accept: application/vnd.example.com.v1+json 其中
后面幾個參數依次為應用名稱(一般為應用域名)、版本號、期望的返回格式。 至于具體把版本號放在什么地方,這個問題一直存在很大的爭議,但由于我們大多數時間都在使用 Endpoints端點就是指向特定資源或資源集合的
至于 URL 是否必須使用連字符( 來看一個反例
再來看一個正列
HTTP 動詞對于資源的具體操作類型,由
其中 1 刪除資源 針對每一個端點來說,下面列出所有可行的
超出 Filtering如果記錄數量很多,服務器不可能都將它們返回給用戶。API
所有 分頁參數 經常使用的、復雜的查詢 GET /trades?status=closed&sort=sortby=name&order=asc
# 可為其定制快捷方式
GET /trades/recently_closed Authentication
Oauth 的端點設計示列
客戶端在獲得 {
"access_token": "token....",
"token_type": "Bearer",
"expires_in": 3600
} 客戶端在請求需要認證的 Authorization: Bearer token... 當超過指定的秒數后, HTTP/1.1 401 Unauthorized
Content-Type: application/json
Cache-Control: no-store
Pragma: no-cache
{
"error": "invalid_token"
} Laravel 開發中, Response所有的 HTTP/1.1 200 ok
Content-Type: application/json
Server: example.com
{
"code": 0,
"msg": "success",
"data": {
"username": "username"
}
} 或 HTTP/1.1 200 ok
Content-Type: application/json
Server: example.com
{
"code": -1,
"msg": "該活動不存在",
} 下表列舉了常見的
只有來自客戶端的請求被正確的處理后才能返回 必須強調的是,所有 1、將錯誤詳細放入 X-MYNAME-ERROR-CODE: 4001
X-MYNAME-ERROR-MESSAGE: Bad authentication token
X-MYNAME-ERROR-INFO: http://docs.example.com/api/v1/authentication 2、直接放入響應實體中; HTTP/1.1 401 Unauthorized
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 10:02:59 GMT
Connection: keep-alive
{"error_code":40100,"message":"Unauthorized"} 考慮到易讀性和客戶端的易處理性,我們 {
"message": "您查找的資源不存在",
"error_code": 404001
} 其中錯誤碼( HTTP/1.1 429 Too Many Requests
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 10:15:52 GMT
Connection: keep-alive
{"error_code":429001,"message":"你操作太頻繁了"} HTTP/1.1 403 Forbidden
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 10:19:27 GMT
Connection: keep-alive
{"error_code":403002,"message":"用戶已禁用"}
{
"message": "直接展示給終端用戶的錯誤信息",
"error_code": "業務錯誤碼",
"error": "供開發者查看的錯誤信息",
"debug": [
"錯誤堆棧,必須開啟 debug 才存在"
]
} 下面詳細列舉了各種情況 API 的返回說明。 200 ok
錯誤示例: HTTP/1.1 200 ok
Content-Type: application/json
Server: example.com
{
"user": {
"id":1,
"nickname":"fwest",
"username": "example"
}
} 正確示例: 1、獲取單個資源詳情 {
"id": 1,
"username": "godruoyi",
"age": 88,
} 2、獲取資源集合 [
{
"id": 1,
"username": "godruoyi",
"age": 88,
},
{
"id": 2,
"username": "foo",
"age": 88,
}
] 3、額外的媒體信息 {
"data": [
{
"id": 1,
"avatar": "https://lorempixel.com/640/480/?32556",
"nickname": "fwest",
"last_logined_time": "2018-05-29 04:56:43",
"has_registed": true
},
{
"id": 2,
"avatar": "https://lorempixel.com/640/480/?86144",
"nickname": "zschowalter",
"last_logined_time": "2018-06-16 15:18:34",
"has_registed": true
}
],
"meta": {
"pagination": {
"total": 101,
"count": 2,
"per_page": 2,
"current_page": 1,
"total_pages": 51,
"links": {
"next": "http://api.example.com?page=2"
}
}
}
} 其中,分頁和其他額外的媒體信息,必須放到 201 created當服務器創建數據成功時,
等,都可以返回 HTTP/1.1 201 created
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
Date: Sun, 24 Jun 2018 09:13:40 GMT
Connection: keep-alive
{
"id": 1,
"avatar": "https:\/\/lorempixel.com\/640\/480\/?32556",
"nickname": "fwest",
"last_logined_time": "2018-05-29 04:56:43",
"created_at": "2018-06-16 17:55:55",
"updated_at": "2018-06-16 17:55:55"
} 也可以返回一個響應實體為空的 HTTP/1.1 201 created
Server: nginx/1.11.9
Content-Type: text/html; charset=UTF-8
Transfer-Encoding: chunked
Date: Sun, 24 Jun 2018 09:12:20 GMT
Connection: keep-alive 這里我們 202 Accepted該狀態碼表示服務器已經接受到了來自客戶端的請求,但還未開始處理。常用短信發送、郵件通知、模板消息推送等這類很耗時需要隊列支持的場景中; 返回該狀態碼時,響應實體 HTTP/1.1 202 Accepted Server: nginx/1.11.9 Content-Type: text/html; charset=UTF-8 Transfer-Encoding: chunked Date: Sun, 24 Jun 2018 09:25:15 GMT Connection: keep-alive 204 No Content該狀態碼表示響應實體不包含任何數據,其中:
HTTP/1.1 204 No Content
Server: nginx/1.11.9
Date: Sun, 24 Jun 2018 09:29:12 GMT
Connection: keep-alive 3xx 重定向所有 HTTP/1.1 302 Found
Server: nginx/1.11.9
Content-Type: text/html; charset=UTF-8
Transfer-Encoding: chunked
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 09:41:50 GMT
Location: https://example.com
Connection: keep-alive
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<meta http-equiv="refresh" content="0;url=https://example.com" />
<title>Redirecting to https://example.com</title>
</head>
<body>
Redirecting to <a href="https://example.com">https://example.com</a>.
</body>
</html> 所有 HTTP/1.1 302 Found
Server: nginx/1.11.9
Content-Type: text/html; charset=UTF-8
Transfer-Encoding: chunked
Date: Sun, 24 Jun 2018 09:52:50 GMT
Location: https://godruoyi.com
Connection: keep-alive 400 Bad Request由于明顯的客戶端錯誤(例如,請求語法格式錯誤、無效的請求、無效的簽名等),服務器 當服務器無法從其他 4xx 類型的狀態碼中找出合適的來表示錯誤類型時,都 HTTP/1.1 400 Bad Request
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 13:22:36 GMT
Connection: keep-alive
{"error_code":40000,"message":"無效的簽名"} 401 Unauthorized該狀態碼表示當前請求需要身份認證,以下情況都
客戶端在收到 HTTP/1.1 401 Unauthorized
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
WWW-Authenticate: JWTAuth
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 13:17:02 GMT
Connection: keep-alive
{"message":"Token Signature could not be verified.","error_code": "40100"} 403 Forbidden該狀態碼可以簡單的理解為沒有權限訪問該請求,服務器收到請求但拒絕提供服務。 如當普通用戶請求操作管理員用戶時, HTTP/1.1 403 Forbidden
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 13:05:34 GMT
Connection: keep-alive
{"error_code":40301,"message":"權限不足"} 404 Not Found該狀態碼表示用戶請求的資源不存在,如
都 405 Method Not Allowed當客戶端使用的 如客戶端調用了 該響應 HTTP/1.1 405 Method Not Allowed
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
Allow: GET, HEAD
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 12:30:57 GMT
Connection: keep-alive
{"message":"405 Method Not Allowed","error_code": 40500} 406 Not Acceptable
Http 協議一般通過請求首部的 Accept 來指定數據格式 408 Request Timeout客戶端請求超時時 409 Confilct該狀態碼表示因為請求存在沖突無法處理。如通過手機號碼提供注冊功能的 HTTP/1.1 409 Conflict
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 12:19:04 GMT
Connection: keep-alive
{"error_code":40900,"message":"手機號已存在"} 410 Gone和 413 Request Entity Too Large該狀態碼表示服務器拒絕處理當前請求,因為該請求提交的實體數據大小超過了服務器愿意或者能夠處理的范圍。 此種情況下,服務器可以關閉連接以免客戶端繼續發送此請求。 如果這個狀況是臨時的,服務器 414 Request-URI Too Long該狀態碼表示請求的 415 Unsupported Media Type通常表示服務器不支持客戶端請求首部 該狀態碼也可用于如:只允許上傳圖片格式的文件,但是客戶端提交媒體文件非法或不是圖片類型,這時 HTTP/1.1 415 Unsupported Media Type
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 12:09:40 GMT
Connection: keep-alive
{"error_code":41500,"message":"不允許上傳的圖片格式"} 429 Too Many Requests該狀態碼表示用戶請求次數超過允許范圍。如 X-RateLimit-Limit: 10 請求速率(由應用設定,其單位一般為小時/分鐘等,這里是 10次/5分鐘) X-RateLimit-Remaining: 0 當前剩余的請求數量 X-RateLimit-Reset: 1529839462 重置時間 Retry-After: 120 下一次訪問應該等待的時間(秒) 列子 HTTP/1.1 429 Too Many Requests
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
X-RateLimit-Limit: 10
X-RateLimit-Remaining: 0
X-RateLimit-Reset: 1529839462
Retry-After: 290
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 11:19:32 GMT
Connection: keep-alive
{"message":"You have exceeded your rate limit.","error_code":42900}
500 Internal Server Error該狀態碼 503 Service Unavailable該狀態碼表示服務器暫時處理不可用狀態,當服務器需要維護或第三方 HTTP/1.1 503 Service Unavailable
Server: nginx/1.11.9
Content-Type: application/json
Transfer-Encoding: chunked
Cache-Control: no-cache, private
Date: Sun, 24 Jun 2018 10:56:20 GMT
Retry-After: 60
Connection: keep-alive
{"error_code":50300,"message":"服務維護中"} 其他 版權聲明版權聲明:自由轉載-非商用-非衍生-保持署名(創意共享3.0許可證) 建議參考Principles of good RESTful API Design(譯) LICENSEMIT License Copyright (c) 2018 godruoyi Permission is hereby granted, free of charge, to any person obtaining a copy The above copyright notice and this permission notice shall be included in all THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 該文章在 2022/4/18 18:07:11 編輯過 |
關鍵字查詢
相關文章
正在查詢... |