1. HTTP GET vs HTTP POST 也許,你會想起一個面試題。HTTP 請求的 GET 與 POST 方式有什么區別?
你可能會回答到:GET方式通過URL提交數據,數據在URL中可以看到;POST 方式,數據放置在HTML HEADER內提交。但是,我們現在從RESTful的資源角度來看待問題,HTTP GET方法是冪等的,所以它適合作為查詢操作,HTTP POST 方法是非冪等的,所以用來表示新增操作。 但是,也有例外,我們有的時候可能需要把查詢方法改造成 HTTP POST 方法。比如,超長(1k)的 GET URL 使用 POST 方法來替代,因為 GET 受到 URL 長度的限制。雖然,它不符合冪等性,但是它是一種折中的方案。
2. HTTP POST vs HTTP PUT 對于 HTTP POST 方法和HTTP PUT方法,我們一般的理解是 POST 表示創建資源,PUT 表示更新資源。當然,這個是正確的理解。 但是,實際上,兩個方法都用于創建資源,更為本質的差別是在冪等性。HTTP POST方法是非冪等,所以用來表示創建資源,HTTP PUT方法是冪等的,因此表示更新資源更加貼切。
3. HTTP PUT vs HTTP PATCH此時,你看會有另外一個問題。HTTP PUT方法和HTTP PATCH方法,都是用來表述更新資源,它們之間有什么區別呢?我們一般的理解是 PUT表示更新全部資源,PATCH表示更新部分資源。首先,這個是我們遵守的準則。根據上面的描述,PATCH方法是非冪等的,因此我們在設計我們服務端的RESTful API的時候,也需要考慮。如果,我們想要明確的告訴調用者我們的資源是冪等的,我的設計更傾向于使用HTTP PUT方法。