• <ul id="cgeq2"></ul>
  • 歡迎您光臨深圳塔燈網絡科技有限公司!
    電話圖標 余先生:13699882642

    網站百科

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

    RESTful API URL 設計

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

    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://www.juherenli.com/21361.html
    相關前端設計
     八年  行業經驗

    多一份參考,總有益處

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

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

    業務熱線:余經理:13699882642

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

    国产成人精品日本亚洲直接| 精品国产污污免费网站入口在线| 国内精品久久久久久野外| 久久天堂AV女色优精品| 日韩精品免费视频| 亚洲精品美女久久久久99小说| 国产精品一二三区| 精品在线免费观看| 精品一区二区三区AV天堂| 99视频精品国在线视频艾草| 国内精品久久久久伊人av| 一区二区国产精品 | 国产精品高清一区二区人妖| 国内精品人妻无码久久久影院导航| 国产青草亚洲香蕉精品久久| 91精品国产麻豆国产自产在线| 亚洲精品中文字幕无码蜜桃| 日韩精品一区二区三区视频| 亚洲最大天堂无码精品区| 精品三级AV无码一区| 国产精品高清一区二区三区| 国产高清精品在线| 国产精品久久久久网站| 十八禁无遮挡99精品国产| 91精品国产福利在线观看| 久久午夜精品视频| 国产三级精品三级在线专区1| 国产69精品久久久久99| 国产精品成人va在线播放| 人妻精品久久无码区| 2020国产精品视频| 日韩精品一区二区三区中文| 国产99视频精品免视看7| 99久久精品国产麻豆| 精品无码人妻久久久久久| 亚洲国产精品尤物yw在线| 精品91一区二区三区| 国产精品jvid在线观看| 国产精品二区高清在线| 99er热精品视频| 蜜臀91精品国产高清在线观看 |