[Web基礎系列]聽說你寫過聊天機器人?你真的知道WebHook,RESTful API?


Webhook Introduction


想像一下假設你現在的Server想要做即時更新

但你只會寫一般Restful API被動的去接收請求,但無法主動的更新所有Client.

Webhook 就是在解決這類的問題,達到Server能夠主動推撥到另一個Client
因這一特性Webhook也稱作反向API


RESTful API

你可能會寫API,但你有照RESTful 的風格進行API開發嗎?,往下來看看這些特點你是否有做到。


HTTP Verbs

我們知道製作API除了要設置路由之外,請求方法也是一個要點,所謂的請求方法也就是標題所說的HTTP Verbs

  • POST: 新增資源,也可以做一些特殊要求 C->Create
  • GET: 取得資源-> Read
  • PUT: 更新資源 -> Update
  • PATCH: 更新部分資源內容 -> Update
  • DELETE: 刪除資源->Delete
  • HEAD:取得HTTP Header

其中GET,HEAD由於實際上都是讀取資源並不會去動到Server Resource


RESTful API相關規範

由於HTTP是無狀態的通訊協定,一件事情不應該分成兩條API組成
參數樣式盡量應保持一致
HATEOAS(Hypermedia as the engine of application state) 應用程式狀態引擎超媒體


URI Nouns

URI: Uniform Resource Identifier,統一資源標識符
URL: Uniform Resource Locator 統一資源定位符

URI = [Prefix] +API Endpoint

URI設計原則

  • 一般資源用複數名詞
  • 唯一資源用單數名詞
  • 資源層級反映在URI上
  • Utility API設計合理即可
  • URI建議小寫可用- _ 分隔但風格要統一

HTTP Status Code

  • 1XX:Information
  • 2XX:Success
  • 3XX:Redirect
  • 4XX:Client Error
  • 5XX:Server Error

HTTP Header

在我們發出HTTP Request的時候會夾帶一些資訊他會描述在請求的Header之中

常見的有

  • Accept 接受資源型態
  • Authorization 認證資訊

HTTP Body

常見格式JSON、XML

更新於