? ? ? ?REST-ful,其中ful代表形容詞,如helpful,powerful。這類形容詞意為"full of,having the quality of"。多加在名詞之后表示“充滿...的、易于...、可...的、富有...的、具有...的”的意思,是蕞常用的形容詞后綴,反義詞后綴是-less。RESTful 則代表滿足REST原則的。
? ? ? ?與任何其他架構風格一樣,REST也有自己的6個引導約束,如果接口需要被稱為RESTful,則必須滿足這些約束,這些原則如下:
? ? ? ?REST的指導原則
? ? ? ?客戶端 - 服務器 - 通過將用戶接口問題與數據存儲問題分開,我們通過簡化服務器組件來提高跨多個平臺的用戶接口的可移植性并提高可伸縮性。
? ? ? ?無狀態 - 從客戶端到服務器的每個請求都必須包含理解請求所需的所有信息,并且不能利用服務器上任何存儲的上下文。因此,會話狀態完全保留在客戶端上。
? ? ? ?可緩存 - 緩存約束要求將對請求的響應中的數據隱式或顯式標記為可緩存或不可緩存。如果響應是可緩存的,則客戶端緩存有權重用該響應數據以用于以后的等效請求。
? ? ? ?統一接口 - 通過將通用性的軟件工程原理應用于組件接口,簡化了整個系統架構,提高了交互的可見性。為了獲得統一的接口,需要多個架構約束來指導組件的行為。REST由四個接口約束定義:資源識別; 通過陳述來處理資源; 自我描述性的信息; 并且,超媒體作為應用程序狀態的引擎。
? ? ? ?分層系統 - 分層系統風格允許通過約束組件行為來使體系結構由分層層組成,這樣每個組件都不能“看到”超出與它們交互的直接層。
? ? ? ?按需編碼(可選) - REST允許通過以小程序或腳本的形式下載和執行代碼來擴展客戶端功能。這通過減少預先實現所需的功能數量來簡化客戶端。
? ? ? ?二、資源
? ? ? ?REST中信息的關鍵抽象是一種資源。可以命名的任何信息可以是資源:文檔或圖像,臨時服務,其他資源的集合,非虛擬對象(例如,人)等。REST使用資源標識符來標識組件之間交互中涉及的特定資源。
? ? ? ?任何特定時間戳的資源狀態稱為資源表示。表示由數據,描述數據的元數據和超媒體鏈接組成,這些鏈接可以幫助客戶轉換到下一個期望的狀態。
? ? ? ?表示的數據格式稱為媒體類型。媒體類型標識定義如何處理表示的規范。真正的RESTful API看起來像超文本。每個可尋址信息單元明確地(例如,鏈接和id屬性)或隱式地(例如,從媒體類型定義和表示結構導出)攜帶地址。
? ? ? ?根據羅伊菲爾丁的說法:
? ? ? ?超文本(或超媒體)意味著信息和控制的同時呈現,使得信息成為用戶(或自動機)通過其獲得選擇和選擇動作的可供性。請記住,超文本不需要是瀏覽器上的HTML(或XML或JSON)。機器在理解數據格式和關系類型時可以跟蹤鏈接。
? ? ? ?此外,資源表示應該是自描述的:客戶端不需要知道資源是員工還是設備。它應該基于與資源相關的媒體類型。因此在實踐中,您蕞終將創建大量自定義媒體類型 - 通常是與一種資源相關聯的一種媒體類型。
? ? ? ?每種媒體類型都定義了默認處理模型。例如,HTML定義了超文本的呈現過程以及每個元素周圍的瀏覽器行為。它與資源方法GET / PUT / POST / DELETE / ...沒有任何關系,除了一些媒體類型元素將定義一個過程模型,其類似于“具有href屬性的錨元素創建一個超文本鏈接,當被選中時,在與CDATA編碼的href屬性對應的URI上調用檢索請求(GET)。“
? ? ? ?三、資源方法
? ? ? ?與REST相關的其他重要事項是用于執行所需轉換的資源方法。許多人錯誤地將資源方法與HTTP GET / PUT / POST / DELETE方法聯系起來。
? ? ? ?Roy Fielding從未提及任何關于在哪種情況下使用哪種方法的建議。他所強調的是它應該是統一的接口。如果你決定HTTP POST將用于更新資源 - 而不是大多數人推薦HTTP PUT - 它沒關系,應用程序接口將是RESTful。
? ? ? ?理想情況下,更改資源狀態所需的所有內容都應該是該資源的API響應的一部分 - 包括方法以及它們將保留表示的狀態。
? ? ? ?應輸入REST API,除了初始URI(書簽)和適用于目標受眾的標準化媒體類型集之外沒有任何先驗知識(即,任何可能使用API的客戶都應該理解)。從那時起,所有應用程序狀態轉換必須由客戶端選擇服務器提供的選擇來驅動,這些選擇存在于接收的表示中或者由用戶對這些表示的操縱所暗示。轉換可以由客戶端對媒體類型和資源通信機制的知識來確定(或限制),這兩者都可以在運行中(例如,按需代碼)進行改進。
? ? ? ?[失敗在這里意味著帶外信息驅動交互而不是超文本。]
? ? ? ?在構建RESTful API時,另一件可以幫助您的是基于查詢的API結果應該由帶有摘要信息的鏈接列表表示,而不是由原始資源表示的數組表示,因為查詢不能代替資源標識。
? ? ? ?REST和HTTP不一樣!!
? ? ? ?很多人更喜歡將HTTP與REST進行比較。REST和HTTP不一樣。
? ? ? ?REST!= HTTP
? ? ? ?但是,由于REST還打算使web(互聯網)更加簡化和標準化,他主張更嚴格地使用REST原則。這也是人們試圖開始將REST與網絡(HTTP)進行比較的地方。Roy fielding在他的論文中沒有提到任何實現指令 - 包括任何協議首要選項和HTTP。到時候,您正在遵循REST的6個指導原則,您可以將您的接口稱為RESTful。
? ? ? ?簡而言之,在REST架構風格中,數據和功能被視為資源,并使用統一資源標識符(URI)進行訪問。通過使用一組簡單,定義明確的操作來執行資源。客戶端和服務器通過使用標準化接口和協議(通常是HTTP)來交換資源的表示。
? ? ? ?資源與其表示分離,以便可以以各種格式訪問其內容,例如HTML,XML,純文本,PDF,JPEG,JSON等。例如,可以使用和使用關于資源的元數據來控制高速緩存,檢測傳輸錯誤,協商適當的表示格式,以及執行認證或訪問控制。蕞重要的是,與資源的每次交互都是無狀態的。
? ? ? ?所有這些原則都有助于RESTful應用程序簡單,輕量和快速。
? ? ? ?以上是南昌APP開發公司百恒科技小編要跟大家聊到的關于RESTful API接口規范的內容,希望能夠對大家有所幫助,想要了解更多關于這方面的內容,歡迎留言咨詢百恒科技,百恒科技專注于南昌APP開發、南昌網站建設開發等互聯網服務!
相關文章推薦? ?:? ? 數據庫SQL開發規范是什么?? ? ??
? ? ? ? ? ? ? ? ? ? ? ? ?MySQL數據庫操作行為規范是什么?? ??