RestFul服務介紹

1. REST介紹

REpresentational State Transfer (REST) 是一種架構原則,其中將 web 服務視爲資源,可以由其 URL 唯一標識。

RESTful Web 服務的關鍵特點是明確使用 HTTP 方法來表示不同的操作的調用。

REST 的基本設計原則對典型 CRUD 操作使用 HTTP 協議方法:

POST - 創建資源

GET - 檢索資源

PUT  更新資源

DELETE - 刪除資源

REST 服務的主要優勢在於:

它們是跨平臺 (Java.netPHP 等)高度可重用的,因爲它們都依賴基本 HTTP 協議。

它們使用基本的 XML,而不是複雜的 SOAP XML,使用非常方便。

基於 REST  web 服務日益成爲後端企業服務集成的首選方法。與基於 SOAP  web 服務相比,它的編程模型簡單,而本機 XML(而不是 SOAP )的使用減少了序列化和反序列化過程的複雜性,並且不再需要其他作用相同的第三方庫。

 

2. 編寫目的

編寫本文的目的是爲了將系統功能進行模塊化、服務化,將用戶的操作以服務的方式提供。系統與系統之間遵循服務規範,將系統與系統之間的交互轉爲定製化服務交互,以實現系統與系統之間的集成

 

3. 編寫原則

可尋址性(Addressability)

REST 中的所有東西都基於資源 的概念。資源與 OOP 中的對象或其他名詞不同,它是一種抽象,必須可以通過 URI 尋址或訪問。

接口一致性(Interface uniformity

 SOAP 或其他標準不同,REST 要求用來操縱資源的方法或動詞不是任意的。這意味着 RESTful 服務的開發人員只能使用 HTTP 支持的方法,比如GETPUTPOSTDELETE等等。因此不需要使用 WSDL 等服務描述語言

無狀態(Statelessness

爲了增強可伸縮性,服務器端不存儲客戶機的狀態信息。這使服務器不與特定的客戶機相綁定,負載平衡變得簡單多了。這還讓服務器更容易監視、更可靠

具象(Representational

客戶機總是與資源的某種具象交互,絕不會直接與資源本身交互。同一資源還可以有多個具象。理論上說,持有資源的具象的任何客戶機應該有操縱底層資源的足夠信息。

  連通性(Connectedness

任何基於 REST 的系統都應該預見到客戶機需要訪問相關的資源,應該在返回的資源具象中包含這些資源。例如,可以以超鏈接的形式包含特定 RESTful 服務的操作序列中的相關步驟,讓客戶機可以根據需要訪問它們。

 

4. 服務使用說明

 1) 當前系統已經提供的服務

 

   2)  GET方式調用服務



說明:
  1.請求方式包括:GET (這裏以area服務爲實例,GET對應每一個服務Resource中的@RequestMapping(value = "treeData", method = RequestMethod.GET))
  2.請求URL:rest服務請求地址,對應XXXServiceResource.java的mapping配置中的value
    @RequestMapping(value = "treeData", method = RequestMethod.GET))
  3.其中GET請求只包含了請求方式和請求的URL,返回的結果以json格式返回給客戶端

 

   3) POST、DELETE、UPDATE方式調用服務



 說明:
  1.請求方式選擇POST、DELETE、UPDATE(這裏以保存收藏功能爲例(PUT請求),對應每一個服Resource中的@RequestMapping(value = "save", method = RequestMethod.PUT))
  2.Json參數: 其中POST、DELETE、UPDATE可能傳遞參數通過json,也可能通過路徑直接拼接參數,這邊以傳遞json到服務端爲實例,對應服務端代碼:
    public JSONObject save(@RequestBody JSONObject obj, BookmarkTag bookmarkTag) {
  3.請求URL:rest服務請求地址,對應XXXServiceResource.java的mapping配置中的value
    @RequestMapping(value = " save", method = RequestMethod.PUT))
  4.返回的結果以json格式返回給客戶端

 

5.  服務列表(僅僅列舉實例)

    1)添加標籤


    2)刪除標籤

    3)更新標籤

    4)獲取標籤列表

歡迎大家一起學習研究相關技術願意瞭解框架技術或者源碼的朋友直接加求求(企鵝):2042849237
更多詳細源碼參考來源: http://minglisoft.cn/technology


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章