顯示廣告
隱藏 ✕
※ 本文為 layzer 轉寄自 ptt.cc 更新時間: 2019-03-14 10:35:23
看板 Soft_Job
作者 jdlee (jdlee)
標題
 Re: [請益] 所以,到底什麼是RESTful API?

時間 Tue Mar 12 14:14:25 2019


※ 引述《thefattiger (LawTea)》之銘言:
: 但查了一下資訊卻還是摸不著頭緒
: 估狗RESTful API 大概都是講到一下幾點
: 1.資源要用URL表示
: 這不是本來就這樣的嗎?
: 2.Server要回傳對應的Http Status Code
: 這不是也本來就這樣的嗎?
: 3.用GET/POST/PUT等動詞表達對資源的操作
: 意思是說, 本來只有GET/POST用法, 但其實還有PUT/PATCH/DELETE等等
: 應該要善加利用這些動詞把操作分得更清楚?
: 4.Stateless
: 這也很常看到,但Http不是本來就Stateless的嗎?
:
: 我的問題主要是,這些東西不是Http本來就有的嗎?

您的問題圍繞在"這不是Http本來就這樣的嗎"。RESTful API是利用
既有的A領域工具解決B領域的問題。B領域的人可能會覺得很新奇,
但是熟悉A領域的人,可能會覺得本來就是這樣,沒什麼特別的。


遙想199x年的古老時代,PC軟體工程師J用Java寫了一個資料處理程式。

另一個PC軟體工程師D跟J說: 我的專案剛好需要你的程式。你的程式

可以copy給我嗎?讓我可以編譯連結到我的專案程式。

J: 不行,這個程式我要申請專利,我不想copy給你。而且,你的程式是
用Delphi寫的,你要如何連結我的Java程式?

網路專家H聽到兩人的談話,也加入討論。
H: 現在網路很流行,何不這樣,J的程式放在J的電腦,不用copy給D。
讓D的電腦裡的程式透過網路呼叫J的程式,傳回結果。

J: 這麼神奇!?但是D的程式要如何透過網路呼叫我的函式呢?如何傳遞
參數呢?

D: 聽說FTP可以用來在網路上傳檔案,我們把它用來傳參數。我把參數
存成檔案,用ftp傳給你,你也把結果存成檔案,用ftp傳回給我。

J: 這個方式聽起來似乎可行,但是感覺執行起來有點麻煩。

H: 現在WWW開始流行,我家阿嬤都在用HTTP瀏覽網站。你們何不使用
HTTP? HTTP的request-response不就好像API函式呼叫嗎?HTTP的url
剛好可以當函式名稱+參數, HTTP的status code剛好也可以拿來當
function error/status code。HTTP的GET/POST/PUT/PATCH/DELETE
剛好可以對應你的資料處理CRUD。如果你的程式專利通過了,你要開放
給全世界上千萬軟體工程師呼叫,剛好HTTP是stateless,可以讓你的
電腦負荷比較小。


D: 太好了,太漂亮了,beautiful! 這種用HTTP做遠端API呼叫的方式
要叫什麼名字呢?

H: 用這種方式,工程師們不用煩惱跨語言編譯連結...等很多問題,
可以省下很多時間,這些時間可以拿來好好休息護肝。我們就叫它
RESTful API吧。

--
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 59.115.157.17
※ 文章代碼(AID): #1SXqv42M (Soft_Job)
※ 文章網址: https://www.ptt.cc/bbs/Soft_Job/M.1552371268.A.096.html
geroge0820: 這篇深得我心 太神了1F 03/12 15:03
PureEatTea: 謝謝你, 你的說明和例子讓科普了我2F 03/12 15:31
BaJiaJhon: 推3F 03/12 15:40
oas: 推推~~ lol4F 03/12 15:42
pxycho: 這一串我最愛這篇5F 03/12 15:55
BBSealion: 讚XD6F 03/12 16:12
DCTmaybe: 滿滿的rest~讚讚7F 03/12 17:33
bheegrl: 推8F 03/12 17:44
leon1757tw: 推9F 03/12 18:32
tz5514: 幹 原來我多年來理解的REST是錯的 這篇才是真。rest 淚推10F 03/12 20:28
vavamos: 這對話好像head first喔XDDDDDDDDDDDDDDDDDDDDDDDDDDDFF11F 03/12 21:36
gpctv: 都是你害我又去google來對照你的說法,謝謝12F 03/12 21:54
Royne: 讚13F 03/12 22:00
hahaRegina: 推~~14F 03/12 22:57
moonxuan: 好像有點可愛15F 03/12 23:25
crazykai: Head First RESTful API!!16F 03/13 00:40
umum29: 很好的說明 當比較XML-RPC SOAP RESTFul都要從歷史演進看17F 03/13 00:53
LERICAL: 推推18F 03/13 01:22
internetms52: 推19F 03/13 07:20
akito117: 推20F 03/13 10:51
mail3403: 忽然恍然大悟 XD21F 03/13 11:54
Daiblo2: 寫得真好懂  推一個~~~22F 03/13 16:38
terry01333: 推23F 03/13 18:40
sa0124: 推24F 03/13 20:06
leo770429: 高手25F 03/13 23:21
wangm4a1: 真的假的!!26F 03/14 01:00
Kennyq: 教得淺顯易懂,像名師的教法27F 03/14 03:08
shorty696820: 太傳神啦XDDD28F 03/14 08:22

--
※ 看板: layzer 文章推薦值: 0 目前人氣: 0 累積人氣: 297 
※ 本文也出現在看板: terievv
※ 文章分類: 程式設計
r)回覆 e)編輯 d)刪除 M)不收藏 ^x)轉錄 同主題: =)首篇 [)上篇 ])下篇