HTTP 請求方式: GET和POST的比較當發送數據時,GET 方法向 URL 添加數據;URL 的長度是受限制的(URL 的最大長度是 2048 個字符)。

什麼是HTTP?
超文本傳輸協議(HyperText Transfer Protocol -- HTTP)是一個設計來使客戶端和服務器順利進行通信的協議。
HTTP在客戶端和服務器之間以request-response protocol(請求-回覆協議)工做。
 
GET - 從指定的服務器中獲取數據
POST - 提交數據給指定的服務器處理
 
GET方法:
使用GET方法時,查詢字符串(鍵值對)被附加在URL地址後面一塊兒發送到服務器:
/test/demo_form.jsp?name1=value1&name2=value2
特色:
  • GET請求可以被緩存
  • GET請求會保存在瀏覽器的瀏覽記錄中
  • 以GET請求的URL可以保存爲瀏覽器書籤
  • GET請求有長度限制
  • GET請求主要用以獲取數據
POST方法:
使用POST方法時,查詢字符串在POST信息中單獨存在,和HTTP請求一塊兒發送到服務器:
POST /test/demo_form.jsp HTTP/1.1
Host: w3schools.com
name1=value1&name2=value2
特色:
  • POST請求不能被緩存下來
  • POST請求不會保存在瀏覽器瀏覽記錄中
  • 以POST請求的URL沒法保存爲瀏覽器書籤
  • POST請求沒有長度限制
GET和POST的區別:
  GE POST
點擊返回/刷新按鈕 沒有影響 數據會從新發送(瀏覽器將會提示用戶「數據被重新提交」)
添加書籤 能夠 不能夠
緩存 能夠 不能夠
編碼類型(Encoding type) application/x-www-form-urlencoded
application/x-www-form-urlencoded or multipart/form-data. 請爲二進制數據使用multipart編碼
歷史記錄 參數保留在瀏覽器歷史中。 參數不會保留在瀏覽器歷史中。
長度限制 當發送數據時,GET 方法向 URL 添加數據;URL 的長度是受限制的(URL 的最大長度是 2048 個字符)。
沒有
數據類型限制 只容許ASCII字符類型 沒有限制。容許二進制數據
安全性 查詢字符串會顯示在地址欄的URL中,不安全,請不要使用GET請求提交敏感數據 由於數據不會顯示在地址欄中,也不會緩存下來或保存在瀏覽記錄中,因此看POST求情比GET請求安全,但也不是最安全的方式。如須要傳送敏感數據,請使用加密方式傳輸
可見性 查詢字符串顯示在地址欄的URL中,可見 查詢字符串不會顯示在地址欄中,不可見
其餘HTTP請求方式
方式 描述
HEAD 與GET請求相似,不一樣在與服務器只返回HTTP頭部信息,沒有頁面內容
PUT 上傳指定URL的描述
DELETE 刪除指定資源
OPTIONS 返回服務器支持的HTTP方法
CONNECT 轉換爲透明TCP/IP隧道的鏈接請求
相關文章
相關標籤/搜索