如何 RESTFul 你的服務(譯)

来源:http://www.cnblogs.com/lookerblue/archive/2017/07/14/7170784.html
-Advertisement-
Play Games

如今無論是社交媒體平臺還是企業解決方案,Web services都不出不在。為了可以跨平臺使用,如何“暴露”你的APIs就顯得非常重要。當前,很多APIs錶面上聲稱是RESTful,但實際上它們是改進過後的RPC。 ...


原文:http://reynders.co/how-restful-is-your-service/
發表於:2013年9月

如今無論是社交媒體平臺還是企業解決方案,Web services都不出不在。為了可以跨平臺使用,如何“暴露”你的APIs就顯得非常重要。當前,很多APIs錶面上聲稱是RESTful,但實際上它們是改進過後的RPC。

許多聲稱實現了REST風格的服務甚至不知道這個詞是什麼意思,因此我來解釋一下什麼是REST,並且告訴你如何RESTful你的服務。

REST and RESTful

Roy Fielding 的定義, Representational State Transfer(REST) 是分散式系統的一種軟體架構風格。例如Web,它依賴於一個無狀態(stateless),客戶端-伺服器(client-server),可緩存的(cache-able)通信協議,比如HTTP。  

/this/does/not/mean/restful, { "neither":"does this" }  

擁有清晰流暢的路由並且返回JSON數據並不意味你的服務已經RESTful。只有當採用REST風格並且遵循某些規則時才是真正的RESTful服務。 

Fielding指出RESTful所需的6個約束,其中至少5個需被重視: 

1. 客戶端-伺服器約束(Client-Server constraint) 

使用統一介面隔離客戶端與伺服器。客戶端不必關心業務邏輯和數據存儲,同樣的,伺服器不必考慮用戶界面。

2. 無狀態約束(Stateless constraint)  

每次請求都包含伺服器所需的所有信息,伺服器沒有存儲狀態信息。  

3. 可緩存約束(Cache-able constraint) 

伺服器響應必須能夠顯式或隱式定義自己是可緩存的(cache-able),允許客戶端復用響應,減少與伺服器之間的頻繁調用,以此來提升性能。  

4. 分層系統約束(Layered System constraint) 

客戶端無需考慮中介組件,如負載平衡和代理,提高系統的可伸縮性。  

5. 統一介面約束(Uniform Interface constraint)  

客戶端與伺服器之間使用統一的基於HTTP協議的URI來定位資源。如前所述,每個信息都包含足夠伺服器完成後續處理的信息,既 HATEOAS(Hypermedia As The Engine Of Application State)。  

6. 按需代碼約束(Code On Demand constraint)  

可選約束。在伺服器返回信息之前,客戶端無需知道如何處理這些信息。通常用於向已完成部署的系統中添加功能。  

RESTful Web APIs  

實現REST的Web應用程式介面和基於HTTP實現RESTful的Web APIs包含以下特性:  

  • 基本URI,例如:http://api.mysystem.com
  • 支持互聯網媒體類型,如:JSON
  • 使用HTTP動詞(HTTP verbs: GET, POST, PUT, DELETE)完成操作
  • 超文本驅動(Hypertext driven)

RESTful Web API 必須易於使用並且提供完整的幫助文檔。  

"If you have to ship an SDK for your RESTful API, it is not a RESTful API" - source  

ASP.NET開發團隊提供了一個基於REST原則構建Web API的開發框架,叫做 ASP.NET Web API,點擊獲得擴展閱讀。  

小記 

前述“約束”並不是一個標準,但不失為構建RESTful風格Web應用的最佳指引。  

目前真正實現RESTful思想的應用屈指可數,大部分還是基於HTTP協議改進的RPC。下次你在研究一個新的API時,可以體會一下是否是真正的RESTful。 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Linux使用小Tips 整理些Linux些常遇到的問題。 修改網卡ens33為eth0 在使用RHEL和Centos7,發現網卡名稱變成了EnoX,挺不習慣。現更改回舊名稱eth0看著順眼。 1. 備份/etc/sysconfig/grub文件 2. 編輯/etc/sysconfig/grub文件 ...
  • 服務端 1 #!/bin/sh 2 # chkconfig: 2345 21 60 3 # description: Saves and restores system entropy pool for \ 4 #create by xiaohu 5 #2014.06.02 6 #This scri ...
  • using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace LINQ01 { class Program {... ...
  • 上一篇博客學習瞭如何簡單的使用多線程。其實普通的多線程確實很簡單,但是一個安全的高效的多線程卻不那麼簡單。所以很多時候不正確的使用多線程反倒會影響程式的性能。 下麵先看一個例子 : 執行結果: 從上面可以看出變數 num 的值不是連續遞增的,輸出也是沒有順序的,而且每次輸出的值都是不一樣的,這是因為 ...
  • using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks; namespace ConsoleApp1{ class Program { ...
  • HTTP模擬工具 開發語言:C#/Winform開發工具:Visual Studio 2017資料庫: SQLite使用框架:界面-MetroModernUI Http請求-RestSharp ORM-Dapper.Net Json解析-Newtonsoft.Json 多線程-SmartThread ...
  • Adding a view to an ASP.NET Core MVC app 在asp.net core mvc中添加視圖 2017-3-4 7 分鐘閱讀時長 本文內容 1.Changing views and layout pages 修改視圖和佈局頁 2.Change the title a ...
  • 做好一個ASP.NET MVC網站,訪問速度非常慢,要幾秒到幾十秒不等的時間才能展現頁面.每隔幾十分鐘就會出現一次這樣的情況.下麵分享優化方法 開發環境是:VS2015 + IIS8+ SQL Server 部署環境是:Windows 2008 R2+ IIS7+ SQL Server 設置IIS回 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...