91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何根據豆瓣api來理解Restful API設計的

發布時間:2021-12-21 13:49:14 來源:億速云 閱讀:154 作者:柒染 欄目:大數據

今天就跟大家聊聊有關如何根據豆瓣api來理解Restful API設計的,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

1.什么是REST

REST全稱是Representational State Transfer,表述狀態轉移的意思。它是在Roy Fielding博士論文首次提出。REST本身沒有創造新的技術、組件或服務,它的理念就是在現有的技術之上,更好的使用現有的 web規范。用REST規范的web服務器,能夠更好的展現資源,客戶端能夠更好的使用資源。每個資源都由URI/ID標識。REST本身跟http無關,但是目前http是與它相關的唯一實例。REST有著優雅、簡潔的特性,本文是根據豆瓣api來談談自己對restful的一些理解。

2.URI規范

  • URI(Uniform Resource Identifiers) 統一資源標示符

  • URL(Uniform Resource Locator) 統一資源定位符

URI 的格式:

URI的格式定義如下:  
URI = scheme "://" authority "/" path [ "?" query ] [ "#" fragment ]
  • uri代表的是一種資源,要做到優雅、簡潔。

  • 最好在api地址標明版本

比如

https://api.douban.com/v2
  • 關于分隔符“/”,比如:

"/"分隔符一般用來對資源層級的劃分,比如:

https://api.douban.com/v2/book/1220562

表述了豆瓣api,version2下的圖書倉庫下的編號為1220562的圖書。
  • URI盡量使用“-”代替下劃線“_“。

  • URI統一使用小寫字母

  • URI不包含文件擴展名

  • 使用?用來過濾資源,比如?limit=10 :指定返回10條記錄。

  • 不使用無意義的字符串、數字,要做到簡潔。

3.正確使用method

  • get -只用做資源的讀取。

  • post-通過用作創建一個新的資源。

  • delete-通過用作資源的刪除。

  • put -通過用作更新資源或者創建資源

  • head-只獲取某個資源的頭部信息。

比如 豆瓣圖書api:

namemethodapi
獲取圖書信息get/v2/book/:id
用戶收藏某本圖書post/v2/book/:id/collection
用戶修改對某本圖書的收藏put/v2/book/:id/collection
用戶刪除對某個圖書的收藏delete/v2/book/:id/collection
  • 另外,在一些不符合curd的情況下,使用 post。

  • 把動作轉換成資源

    比如,上述接口中,用戶收藏某本書對外暴露的接口是”/v2/book/:id/collection”,收藏動作通過post方法來展現,而不直接寫著api中,collection “收藏”,名次,動作直接轉換成了資源。

4.選擇合適的狀態碼

http請求需要返回狀態碼,約定俗成的狀態碼能夠幫助開發團隊提高溝通效率。

  • 2xx: 請求正常處理并返回

  • 3xx: 重定向

  • 4xx: 客戶端請求有錯誤

  • 5xx: 服務端請求有錯誤

比如豆瓣api返回的狀態碼說明:

狀態碼含義說明
200ok請求成功
201created創建成功
202accepted更新成功
400bad request請求不存在
401unauthorized未授權
403forbidden禁止訪問
404not found資源不存在
500internal server error內部錯誤

5.使用通用的錯誤碼

通用錯誤碼,具體產品由具體產品api給出。比如豆瓣api:

錯誤碼錯誤信息含義
999unknow_v2_error未知錯誤
1000need_permission需要權限
1001uri_not_found資源不存在
….

太多了,只列出幾條,具體見豆瓣 api。

6. 安全

這部分內容不屬于這篇文章,但是稍微說明下:

  • 使用https

  • 使用jwt驗證

  • 使用參數簽名,防止參數被篡改。

  • 使用權限驗證,shiro ,或者自己建數據庫(用戶、角色、權限)

7.api文檔

接口文檔的編寫至關重要,最好是寫一個在線接口文檔。接口文檔能夠方便團隊查閱,減少不必要的溝通。如果對外公開api,api文檔的質量直接反應了一個公司的技術水平,甚至一個公司的文化氣質。

看完上述內容,你們對如何根據豆瓣api來理解Restful API設計的有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

民县| 南阳市| 关岭| 建昌县| 楚雄市| 清河县| 如东县| 新巴尔虎左旗| 利辛县| 苍溪县| 涟源市| 武鸣县| 阳东县| 三河市| 巴楚县| 泗阳县| 隆林| 石楼县| 乐业县| 沙河市| 荔浦县| 乌兰浩特市| 佛坪县| 二连浩特市| 广安市| 承德县| 江山市| 内江市| 花莲县| 勃利县| 武宁县| 望江县| 宜黄县| 邹城市| 松潘县| 荆门市| 新乡县| 陵川县| 宜川县| 东阿县| 平顺县|