什麼是REST-ful,以及REST-ful的實現

###REST 指的是一組架構約束條件和原則前端

  • Web 應用程序最重要的 REST 原則是:客戶端和服務器之間的交互,在請求之間是無狀態的;客戶端的每一個請求都必須包含理解請求所必需的信息;服務器在請求之間的任什麼時候間點重啓,客戶端不會獲得通知;無狀態請求能夠由任何可用服務器回答,十分適合雲計算之類的環境;客戶端能夠緩存數據以改進性能。數據庫

  • 在服務器端,應用程序狀態和功能能夠分爲各類資源:每一個資源都使用 URI (Universal Resource Identifier) 獲得一個唯一的地址。全部資源都共享統一的界面,以便在客戶端和服務器之間傳輸狀態。使用的是標準的 HTTP 方法,好比 GET、PUT、POST 和 DELETE。設計模式

  • 另外一個重要的 REST 原則是分層系統:這表示組件沒法瞭解它與之交互的中間層之外的組件。經過將系統知識限制在單個層,能夠限制整個系統的複雜性,促進了底層的獨立性。瀏覽器

    當 REST 架構的約束條件做爲一個總體應用時,將生成一個能夠擴展到大量客戶端的應用程序。它還下降了客戶端和服務器之間的交互延遲。統一界面簡化了整個系統架構,改進了子系統之間交互的可見性。REST 簡化了客戶端和服務器的實現。緩存

###REST-ful的實現:構建 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 來處理服務器上資源之間的交互。curl

圖 1 中的 Web 瀏覽器客戶端做爲 GUI 的前端,使用表示層中的 Browser Request Handler 生成的 HTML 提供顯示功能。Browser Requester Handler 可使用 MVC 模型(JSF、Struts 或 Spring 都是 Java 的例子)。它從瀏覽器接受請求,從業務邏輯層請求服務,生成表示並對瀏覽器作出響應。表示供用戶在瀏覽器中顯示使用。表示不只包含內容,還包含顯示的屬性,好比 HTML 和 CSS。函數

多層 Web 應用程序環境圖

業務規則能夠集中到業務邏輯層,該層充當表示層和數據訪問層之間的數據交換的中間層。數據以域對象或值對象的形式提供給表示層。從業務邏輯層中解耦 Browser Request Handler 和 Resource Request Handler 有助於促進代碼重用,並能實現靈活和可擴展的架構。此外,因爲未來可使用新的 REST 和 MVC 框架,實現它們變得更加容易,無需重寫業務邏輯層。

數據訪問層提供與數據存儲層的交互,可使用 DAO 設計模式或者對象-關係映射解決方案(如 Hibernate、OJB 或 iBATIS)實現。做爲替代方案,業務層和數據訪問層中的組件能夠實現爲 EJB 組件,並取得 EJB 容器的支持,該容器能夠爲組件生命週期提供便利,管理持久性、事務和資源配置。可是,這須要一個聽從 Java EE 的應用服務器(好比 JBoss),而且可能沒法處理 Tomcat。該層的做用在於針對不一樣的數據存儲技術,從業務邏輯中分離數據訪問代碼。數據訪問層還能夠做爲鏈接其餘系統的集成點,能夠成爲其餘 Web 服務的客戶端。

數據存儲層包括數據庫系統、LDAP 服務器、文件系統和企業信息系統(包括遺留系統、事務處理系統和企業資源規劃系統)。使用該架構,您能夠開始看到 RESTful Web 服務的力量,它能夠靈活地成爲任何企業數據存儲的統一 API,從而向以用戶爲中心的 Web 應用程序公開垂直數據,並自動化批量報告腳本。

相關文章
相關標籤/搜索