當前位置:首頁 » 雲伺服器 » restful伺服器搭建

restful伺服器搭建

發布時間: 2023-01-11 08:22:38

1. RESTful 架構 (表現層狀態轉移)

概念是 Roy Thomas Fielding在他2000年的博士論文中提出的。他參與制定了 HTTP 1.0 和 HTTP 1.1 協議。

他希望能基於網路現有的協議基礎上創建一個功能強大,性能游戲,適宜通信的架構。

如含義一樣,將從邏輯上將業務實現拆分為客戶端與服務端實現。

通過分離設計,能簡化兩邊的設計復雜度,提高其可擴展性。

資源是 RESTful 的主體,主要指代互聯網上的一個實體,可以是一段文本、一張圖片、一首歌曲、一種服務,總之就是一個具體的實在。資源通過 URI 來唯一標識。

資源的信息載體形式,叫做表現層。他可以是文本、XML、JSON 或者是一個二進制文件。它的具體表現形式,應該在HTTP請求的頭信息中用Accept和Content-Type欄位指定,這兩個欄位才是對"表現層"的描述。

互聯網通信協議HTTP協議,是一個無狀態協議。這意味著,所有的狀態都保存在伺服器端。因此,如果客戶端想要操作伺服器,必須通過某種手段,讓伺服器端發生"狀態轉化"(State Transfer)。而這種轉化是建立在表現層之上的,所以就是"表現層狀態轉化"。

在 HTTP 中,我們一般通過四種 HTTP 動詞(verb)來對應資源的變化:GET用來獲取資源,POST用來新建資源(也可以用於更新資源),PUT用來更新資源,DELETE用來刪除資源。

相應的狀態的交互應當是無狀態的(ServerLess)這是 HTTP 的特性所決定的,要求每次請求包含伺服器需要的所有信息,這樣可以很好的確保每一次變化的可預測性,進而提高可靠性,也能增進可擴展性。

綜合上面的解釋,我們總結一下什麼是RESTful架構:

(1)每一個URI代表一種資源;

(2)客戶端和伺服器之間,傳遞這種資源的某種表現層;

(3)客戶端通過四個HTTP動詞,對伺服器端資源進行操作,實現"表現層狀態轉化"。

HTTP 請求是互聯網架構中重要的一環,其在 TCP 連接的基礎上,實現了語義化,緩存機制,無狀態等等特性。在互聯網上也有不錯的性能,REST 常常會基於 HTTP 協議的基礎上實現其核心概念。

論文中對 HTTP 與 REST 相適宜的論述提及了幾點:

這里是論文中對 HTTP Code 來表現業務相應狀態的相關表述:

原文: https://martinfowler.com/articles/richardsonMaturityModel.html

他講這個模型層次分為四級,大概如下所示:

利用 HTTP 協議做數據交換,所有的參數描述通過 url 或者 POST body 形式通知伺服器,返回相應的數據,此級別通常都是基於 。實質上就是基於 HTTP 的 RPC(遠程過程調用),具體交付的細節完全由相關規范或團隊內部約定解決。

根據理解設計了一份請求交互:

將 API 按照 RESTful 中資源的方式進行劃分,初步有了自我描述(self description)的特性了,客戶端可以對相關的資源進行更加細致的操作。

根據理解設計了一份請求交互:

這個級別有更加進一步的利用了 HTTP 的特性,增加了對 HTTP verb (比如 GET 表示查詢、POST 表示創建、PUT 表示修改、DELETE 表示 等等)的運用,並且運用原有的 HTTP response status 來表徵業務上請求的成功與失敗,一般項目常見的 RESTful 運用基本都接近這個級別。

這個請求基本就和我們平時使用的 RESTful api 很接近了:

這個基本也稱作 HATEOAS (Hypertext As The Engine Of Application State),這個級別是 RESTful 最復雜的實現,這個級別最理想的情況是,不需要特別復雜 API 文檔進行描述的,這里的 API 設計最大化的實現了 RESTful 的自我描述特性。這種方案雖然引入很大的復雜性,但是最大限度的將 API 設計變得配置化了,所有 API 設計將會基於更加抽象的工作流設計了,稍後再做解釋:

本階段的相關請求模型大概是這樣的:

可以看出,從查詢到最終結果,都是由第一個 api 的返回的資源列表和操作項,引導向後面的操作,這樣,後端在設計 API 的時候,需要考慮從一條業務 workflow 的角度去設計。這樣只要整個流程不變,局部的數據變化,只需要修改後端的相關配置即可,這樣業務可以很大程度的配置化。

2. REST是什麼如何實現RESTful

什麼是REST?
REST (REpresentation State Transfer) 描述了一個架構樣式的網路系統,比如 web 應用程序。它首次出現在 2000 年 Roy Fielding 的博士論文中,他是 HTTP 規范的主要編寫者之一。REST 指的是一組架構約束條件和原則。滿足這些約束條件和原則的應用程序或設計就是 RESTful。
Web 應用程序最重要的 REST 原則是,客戶端和伺服器之間的交互在請求之間是無狀態的。從客戶端到伺服器的每個請求都必須包含理解請求所必需的信息。如果伺服器在請求之間的任何時間點重啟,客戶端不會得到通知。此外,無狀態請求可以由任何可用伺服器回答,這十分適合雲計算之類的環境。客戶端可以緩存數據以改進性能。
在伺服器端,應用程序狀態和功能可以分為各種資源。資源是一個有趣的概念實體,它向客戶端公開。資源的例子有:應用程序對象、資料庫記錄、演算法等等。每個資源都使用 URI (Universal Resource Identifier) 得到一個惟一的地址。所有資源都共享統一的界面,以便在客戶端和伺服器之間傳輸狀態。使用的是標準的 HTTP 方法,比如 GET、PUT、POST 和 DELETE。Hypermedia 是應用程序狀態的引擎,資源表示通過超鏈接互聯。
另一個重要的 REST 原則是分層系統,這表示組件無法了解它與之交互的中間層以外的組件。通過將系統知識限制在單個層,可以限制整個系統的復雜性,促進了底層的獨立性。
當 REST 架構的約束條件作為一個整體應用時,將生成一個可以擴展到大量客戶端的應用程序。它還降低了客戶端和伺服器之間的交互延遲。統一界面簡化了整個系統架構,改進了子系統之間交互的可見性。REST 簡化了客戶端和伺服器的實現。
RESTful的實現:RESTful Web 服務與 RPC 樣式的 Web 服務
了解了什麼是什麼是REST,我們再看看RESTful的實現。最近,使用 RPC 樣式架構構建的基於 SOAP 的 Web 服務成為實現 SOA 最常用的方法。RPC 樣式的 Web 服務客戶端將一個裝滿數據的信封(包括方法和參數信息)通過 HTTP 發送到伺服器。伺服器打開信封並使用傳入參數執行指定的方法。方法的結果打包到一個信封並作為響應發回客戶端。客戶端收到響應並打開信封。每個對象都有自己獨特的方法以及僅公開一個 URI 的 RPC 樣式 Web 服務,URI 表示單個端點。它忽略 HTTP 的大部分特性且僅支持 POST 方法。
由於輕量級以及通過 HTTP 直接傳輸數據的特性,Web 服務的 RESTful 方法已經成為最常見的替代方法。可以使用各種語言(比如 Java 程序、Perl、Ruby、Python、PHP 和 Javascript[包括 Ajax])實現客戶端。RESTful Web 服務通常可以通過自動客戶端或代表用戶的應用程序訪問。但是,這種服務的簡便性讓用戶能夠與之直接交互,使用它們的 Web 瀏覽器構建一個 GET URL 並讀取返回的內容。
在 REST 樣式的 Web 服務中,每個資源都有一個地址。資源本身都是方法調用的目標,方法列表對所有資源都是一樣的。這些方法都是標准方法,包括 HTTP GET、POST、PUT、DELETE,還可能包括 HEADER 和 OPTIONS。
在 RPC 樣式的架構中,關注點在於方法,而在 REST 樣式的架構中,關注點在於資源 —— 將使用標准方法檢索並操作信息片段(使用表示的形式)。資源表示形式在表示形式中使用超鏈接互聯。
Leonard Richardson 和 Sam Ruby 在他們的著作 RESTful Web Services 中引入了術語 REST-RPC 混合架構。REST-RPC 混合 Web 服務不使用信封包裝方法、參數和數據,而是直接通過 HTTP 傳輸數據,這與 REST 樣式的 Web 服務是類似的。但是它不使用標準的 HTTP 方法操作資源。它在 HTTP 請求的 URI 部分存儲方法信息。好幾個知名的 Web 服務,比如 Yahoo 的 Flickr API 和 del.icio.us API 都使用這種混合架構。
RESTful的實現:RESTful Web 服務的 Java 框架
有兩個 Java 框架可以幫助構建 RESTful Web 服務。erome Louvel 和 Dave Pawson 開發的 Restlet(見 參考資料)是輕量級的。它實現針對各種 RESTful 系統的資源、表示、連接器和媒體類型之類的概念,包括 Web 服務。在 Restlet 框架中,客戶端和伺服器都是組件。組件通過連接器互相通信。該框架最重要的類是抽象類 Uniform 及其具體的子類 Restlet,該類的子類是專用類,比如 Application、Filter、Finder、Router 和 Route。這些子類能夠一起處理驗證、過濾、安全、數據轉換以及將傳入請求路由到相應資源等操作。Resource 類生成客戶端的表示形式。
JSR-311是 Sun Microsystems 的規范,可以為開發 RESTful Web 服務定義一組 Java API。Jersey是對 JSR-311 的參考實現。
JSR-311 提供一組注釋,相關類和介面都可以用來將 Java 對象作為 Web 資源展示。該規范假定 HTTP 是底層網路協議。它使用注釋提供 URI 和相應資源類之間的清晰映射,以及 HTTP 方法與 Java 對象方法之間的映射。API 支持廣泛的 HTTP 實體內容類型,包括 HTML、XML、JSON、GIF、JPG 等。它還將提供所需的插件功能,以允許使用標准方法通過應用程序添加其他類型。
RESTful的實現:構建 RESTful Web 服務的多層架構
RESTful Web 服務和動態 Web 應用程序在許多方面都是類似的。有時它們提供相同或非常類似的數據和函數,盡管客戶端的種類不同。例如,在線電子商務分類網站為用戶提供一個瀏覽器界面,用於搜索、查看和訂購產品。如果還提供 Web 服務供公司、零售商甚至個人能夠自動訂購產品,它將非常有用。與大部分動態 Web 應用程序一樣,Web 服務可以從多層架構的關注點分離中受益。業務邏輯和數據可以由自動客戶端和 GUI 客戶端共享。惟一的不同點在於客戶端的本質和中間層的表示層。此外,從數據訪問中分離業務邏輯可實現資料庫獨立性,並為各種類型的數據存儲提供插件能力。
圖 1 展示了自動化客戶端,包括 Java 和各種語言編寫的腳本,這些語言包括 Python、Perl、Ruby、PHP 或命令行工具,比如 curl。在瀏覽器中運行且作為 RESTful Web 服務消費者運行的 Ajax、Flash、JavaFX、GWT、博客和 wiki 都屬於此列,因為它們都代表用戶以自動化樣式運行。自動化 Web 服務客戶端在 Web 層向 Resource Request Handler 發送 HTTP 響應。客戶端的無狀態請求在頭部包含方法信息,即 POST、GET、PUT 和 DELETE,這又將映射到 Resource Request Handler 中資源的相應操作。每個請求都包含所有必需的信息,包括 Resource Request Handler 用來處理請求的憑據。
從 Web 服務客戶端收到請求之後,Resource Request Handler 從業務邏輯層請求服務。Resource Request Handler 確定所有概念性的實體,系統將這些實體作為資源公開,並為每個資源分配一個惟一的 URI。但是,概念性的實體在該層是不存在的。它們存在於業務邏輯層。可以使用 Jersey 或其他框架(比如 Restlet)實現 Resource Request Handler,它應該是輕量級的,將大量職責工作委託給業務層。
Ajax 和 RESTful Web 服務本質上是互為補充的。它們都可以利用大量 Web 技術和標准,比如 HTML、JavaScript、瀏覽器對象、XML/JSON 和 HTTP。當然也不需要購買、安裝或配置任何主要組件來支持 Ajax 前端和 RESTful Web 服務之間的交互。RESTful Web 服務為 Ajax 提供了非常簡單的 API 來處理伺服器上資源之間的交互。
圖 1 中的 Web 瀏覽器客戶端作為 GUI 的前端,使用表示層中的 Browser Request Handler 生成的 HTML 提供顯示功能。Browser Requester Handler 可以使用 MVC 模型(JSF、Struts 或 Spring 都是 Java 的例子)。它從瀏覽器接受請求,從業務邏輯層請求服務,生成表示並對瀏覽器做出響應。表示供用戶在瀏覽器中顯示使用。表示不僅包含內容,還包含顯示的屬性,比如 HTML 和 CSS。

業務規則可以集中到業務邏輯層,該層充當表示層和數據訪問層之間的數據交換的中間層。數據以域對象或值對象的形式提供給表示層。從業務邏輯層中解耦 Browser Request Handler 和 Resource Request Handler 有助於促進代碼重用,並能實現靈活和可擴展的架構。此外,由於將來可以使用新的 REST 和 MVC 框架,實現它們變得更加容易,無需重寫業務邏輯層。
數據訪問層提供與數據存儲層的交互,可以使用 DAO 設計模式或者對象-關系映射解決方案(如 Hibernate、OJB 或 iBATIS)實現。作為替代方案,業務層和數據訪問層中的組件可以實現為 EJB 組件,並取得 EJB 容器的支持,該容器可以為組件生命周期提供便利,管理持久性、事務和資源配置。但是,這需要一個遵從 Java EE 的應用伺服器(比如 JBoss),並且可能無法處理 Tomcat。該層的作用在於針對不同的數據存儲技術,從業務邏輯中分離數據訪問代碼。數據訪問層還可以作為連接其他系統的集成點,可以成為其他 Web 服務的客戶端。
數據存儲層包括資料庫系統、LDAP 伺服器、文件系統和企業信息系統(包括遺留系統、事務處理系統和企業資源規劃系統)。使用該架構,您可以開始看到 RESTful Web 服務的力量,它可以靈活地成為任何企業數據存儲的統一 API,從而向以用戶為中心的 Web 應用程序公開垂直數據,並自動化批量報告腳本。

3. c#resful服務端怎麼創建

是restful吧,
創建MVC項目,選擇WEBAPI默認符合restful風格的API項目。

熱點內容
新手學java7編程 發布:2025-04-03 12:17:27 瀏覽:870
某寶演算法 發布:2025-04-03 12:12:26 瀏覽:284
腳本模擬滑鼠點擊 發布:2025-04-03 12:06:19 瀏覽:317
老安卓介面是什麼 發布:2025-04-03 11:57:31 瀏覽:761
nginx資源伺服器搭建 發布:2025-04-03 11:44:52 瀏覽:406
安卓開發和嵌入式哪個難 發布:2025-04-03 11:25:09 瀏覽:318
ftp鏈接本地虛擬機 發布:2025-04-03 11:25:02 瀏覽:793
手機扣扣怎麼找回密碼 發布:2025-04-03 11:24:17 瀏覽:222
安卓平板上做記事本哪個好用 發布:2025-04-03 11:21:27 瀏覽:865
android圖片的大小 發布:2025-04-03 11:20:08 瀏覽:469