<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??一站式輕松地調用各大LLM模型接口,支持GPT4、智譜、豆包、星火、月之暗面及文生圖、文生視頻 廣告
                ## 1. restful開發風格 ### 1.1 原因 1. 網絡程序分為前端和后端兩部分,前端設備多種多樣(筆記本,手機,其他專用設備)。 2. 為了解決多種前端設備與后端服務的信息(數據)交換,所以要同一開發規范 ### 1.1 restful特點 > 1. 在RESTful架構中,每個網址代表一種資源(resource),所以網址中不能有動詞,只能有名詞,而且所用的名詞往往與數據庫的表格名對應。一般來說,數據庫中的表都是同種記錄的"集合"(collection),所以API中的名詞也應該使用復數。 舉例來說,有一個API提供動物園(zoo)的信息,還包括各種動物和雇員的信息,則它的路徑應該設計成下面這樣。 ~~~ https://api.example.com/v1/zoos https://api.example.com/v1/animals https://api.example.com/v1/employees ~~~ > 3. 一般資源操作只有新增、刪除、查詢、更新,對應HTTP協議中四類請求:POST、DELETE、GET、PUT。其中,后三個操作是冪等的。(什么是冪等?) > 4. 查詢資源時,更多的參數,比如分頁、排序、過濾條件,一般都會放在URL的查詢部分(Query String)。 > 5. 新增、更新資源,關于資源實體的內容,一般放在請求體(Request Body)中。 **實際發送請求,還需要有動詞,表示對該資源執行什么樣的操作。那么超出這個范圍的操作該如何擴展?** REST操作返回什么內容?對于刪除、新增、更新等操作,通常是返回操作是否成功的標識;如果失敗,需要返回錯誤代碼和消息,方便客戶端做進一步處理。如果是查詢操作,通常包含實體或者實體列表。 在最佳實踐中,應當還應該返回與此操作相關的其他操作。比如,查詢得到實體的響應中,應包含該實體的刪除、更新操作的地址。 請求和返回的Body,采用什么格式?常見的格式包括XML/JSON/HTML。 ### 1.2 資源操作 于資源的具體操作類型,由HTTP動詞表示。常用的HTTP動詞有下面五個(括號里是對應的SQL命令)。 ~~~ GET(SELECT):從服務器取出資源(一項或多項)。 POST(CREATE):在服務器新建一個資源。 PUT(UPDATE):在服務器更新資源(客戶端提供改變后的完整資源)。 PATCH(UPDATE):在服務器更新資源(客戶端提供改變的屬性)。 DELETE(DELETE):從服務器刪除資源。 ~~~ REST的核心在于,當你設計一個系統的時候,資源是第一位的考慮,你首先從資源的角度進行系統的拆分、設計,而不是像以往一樣以操作為角度來進行設計 我們平時搞系統是這樣的: > 1. 有新建用戶功能 > 2. 新建用戶需要一個URL > 3. 往這個URL發送的數據要定義好 > 4. 開始寫后端和前端 ### 1.3 URI 可以用一個URI(統一資源定位符)指向資源,即每個URI都對應一個特定的資源。要獲取這個資源,訪問它的URI就可以,因此URI就成了每一個資源的地址或識別符。一般的,每個資源至少有一個URI與之對應,最典型的URI即URL。(uri是資源定位的總稱包括url,file,ftp) ### 1.4 無狀態 1. 所謂無狀態的,即所有的資源,都可以通過URI定位,而且這個定位與其他資源無關,也不會因為其他資源的變化而改變。 2. 有狀態和無狀態的區別,舉個簡單的例子說明一下。如查詢員工的工資,如果查詢工資是需要登錄系統,進入查詢工資的頁面,執行相關操作后,獲取工資的多少,則這種情況是有狀態的,因為查詢工資的每一步操作都依賴于前一步操作,只要前置操作不成功,后續操作就無法執行;**如果輸入一個url即可得到指定員工的工資,則這種情況是無狀態的,因為獲取工資不依賴于其他資源或狀態,且這種情況下,員工工資是一個資源,由一個url與之對應,可以通過HTTP中的GET方法得到資源,這是典型的RESTful風格。**
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看