[HTTP]HTTP/1.1 協議Expect: 100-continue


 

 在追蹤請求時發現了這么一個http頭

基礎知識背景:
1)“Expect: 100-continue”的來龍去脈:
HTTP/1.1 協議里設計 100 (Continue) HTTP 狀態碼的的目的是,在客戶端發送 Request Message 之前,HTTP/1.1 協議允許客戶端先判定服務器是否願意接受客戶端發來的消息主體(基於 Request Headers)。
即, Client 和 Server 在 Post (較大)數據之前,允許雙方“握手”,如果匹配上了,Client 才開始發送(較大)數據。
這么做的原因是,如果客戶端直接發送請求數據,但是服務器又將該請求拒絕的話,這種行為將帶來很大的資源開銷。

協議對 HTTP/1.1 clients 的要求是:
如果 client 預期等待“100-continue”的應答,那么它發的請求必須包含一個 " Expect: 100-continue" 的頭域!

2)libcurl 發送大於1024字節數據時啟用“Expect:100-continue‘特性:
這也就是 Laruence 在 2011 年撰文所寫的:

在使用 curl 做 POST 的時候,當要 POST 的數據大於 1024 字節的時候,curl 並不會直接就發起 POST 請求,而是會分為兩步:
1. 發送一個請求,包含一個 "Expect: 100-continue" 頭域,詢問 Server 是否願意接收數據;
2. 接收到 Server 返回的 100-continue 應答以后,才把數據 POST 給 Server;
這是 libcurl 的行為。

於是,這樣就有了一個問題, 並不是所有的Server都會正確應答100-continue, 比如lighttpd, 就會返回417 “Expectation Failed”, 則會造成邏輯出錯,,
要解決的辦法也挺容易:
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Expect:'));

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM