一区二区三区欧美日韩-一区二区三区欧美-一区二区三区免费在线视频-一区二区三区免费在线观看-久久精品店-久久精品第一页

歡迎您光臨深圳塔燈網絡科技有限公司!
電話圖標 余先生:13699882642

網站百科

為您解碼網站建設的點點滴滴

RESTful API URL 設計

發表日期:2019-09 文章編輯:小燈 瀏覽次數:3878

RESTful?是目前最流行的 API 設計規范,也是各公司招聘面試的項目之一。很多人對 RESTful API 的設計還不是很規范,于是便有了本文。

URL 的設計,一般我們會采用:動詞 + 賓語的形式表示。

RESTful 的核心思想就是,客戶端發出的數據操作指令都是"動詞 + 賓語"的結構。比如,GET /articles這個命令,GET是動詞,/articles是賓語。

動詞通常就是五種 HTTP 方法,對應 CRUD 操作。

  • GET:讀取(Read)
  • POST:新建(Create)
  • PUT:更新(Update)
  • PATCH:更新(Update),通常是部分更新
  • DELETE:刪除(Delete)

根據 HTTP 規范,動詞一律大寫。

有些客戶端只能使用GET和POST這兩種方法。服務器必須接受POST模擬其他三個方法(PUT、PATCH、DELETE)。

這時,客戶端發出的 HTTP 請求,要加上X-HTTP-Method-Override屬性,告訴服務器應該使用哪一個動詞,覆蓋POST方法。

POST /api/Person/4 HTTP/1.1X-HTTP-Method-Override: PUT

上面代碼中,X-HTTP-Method-Override指定本次請求的方法是PUT,而不是POST。

在 SpringMVC 中會添加一個?HiddenHttpMethodFilter 過濾器。它會將表單上隱藏域_method屬性改為put或者delete等再進行提交。因為只有form表單才具有post方法,而這個過濾器也只能將post方法轉化,get則不行。不懂的可以看這篇文章:https://blog.csdn.net/jaryle/article/details/73656426。

賓語就是 API 的 URL,是 HTTP 動詞作用的對象。它應該是名詞,不能是動詞。比如,/articles這個 URL 就是正確的,而下面的 URL 不是名詞,所以都是錯誤的。

  • /getAllCars
  • /createNewCar
  • /deleteAllRedCars

既然 URL 是名詞,那么應該使用復數,還是單數?

這沒有統一的規定,但是常見的操作是讀取一個集合,比如GET /articles(讀取所有文章),這里明顯應該是復數。

為了統一起見,建議都使用復數 URL,比如GET /articles/2要好于GET /article/2。

常見的情況是,資源需要多級分類,因此很容易寫出多級的 URL,比如獲取某個作者的某一類文章。

GET /authors/12/categories/2

這種 URL 不利于擴展,語義也不明確,往往要想一會,才能明白含義。

更好的做法是,除了第一級,其他級別都用查詢字符串表達。

GET /authors/12?categories=2

下面是另一個例子,查詢已發布的文章。你可能會設計成下面的 URL。

GET /articles/published

查詢字符串的寫法明顯更好。

GET /articles?published=true

RESTful API 最好的例子就是 github 網站。大家經常使用,一定不陌生。所以可以借鑒 github 上的資源命名方式來開發自己的產品,設計自己的?RESTful API 和 URL。


本頁內容由塔燈網絡科技有限公司通過網絡收集編輯所得,所有資料僅供用戶學習參考,本站不擁有所有權,如您認為本網頁中由涉嫌抄襲的內容,請及時與我們聯系,并提供相關證據,工作人員會在5工作日內聯系您,一經查實,本站立刻刪除侵權內容。本文鏈接:http://m.junxiaosheng.cn/21361.html
相關前端設計
 八年  行業經驗

多一份參考,總有益處

聯系深圳網站公司塔燈網絡,免費獲得網站建設方案及報價

咨詢相關問題或預約面談,可以通過以下方式與我們聯系

業務熱線:余經理:13699882642

Copyright ? 2013-2018 Tadeng NetWork Technology Co., LTD. All Rights Reserved.    

主站蜘蛛池模板: abp-146| 武侠艳妇屈辱的张开双腿| 热九九99香蕉精品品| 中国老女人xxhd69| 电影果冻传媒在线播放| 蜜臀AV精品久久无码99| 一个人看的HD免费高清视频| 国产一级特黄aa毛片| 哇嘎在线精品视频在线观看| 成人毛片100部免费看| 秋秋影视午夜福利高清| JEALOUSVUE成熟老师APP| 暖暖日本免费播放| japansemature护士| 日本免费一区二区三区四区五六区 | 精品久久日日躁夜夜躁AV| 亚洲电影成人 成人影院| 国产精品成人在线播放| 午夜快车神马影视| 国产乱人精品视频AV麻豆| 午夜精品久久久久久久爽牛战| 国产国产乱老熟视频网站| 体内精69xxxxxx喷潮| 国产精品成人自拍| 亚洲精品国产AV成人毛片| 黄色三级网址| 欲奴第一季在线观看全集| 久久婷婷五月综合色情| 52av我爱| 日本双渗透| 国产在线观看91精品| 艳鉧动漫1~6全集观看在线| 久久精品嫩草影院免费看| 2020美女视频黄频大全视频| 免费看a毛片| 处破女免费播放| 午夜DV内射一区区| 精品无码久久久久久动漫 | 色多多旧版污污破解版| 国产精品爽爽久久久久久竹菊 | 中文字幕在线久热精品|