HTTP 1.1默認支持斷點續傳。
關聯header如下:
Range:用於客戶端到服務端的請求,可以通過改字段指定下載文件的某一段大小及其單位,字節偏移從0開始。典型格式:
Ranges: (unit=first byte pos)-[last byte pos]
Ranges: bytes=4000- 下載從第4000字節開始到文件結束部分
Ranges: bytes=0~N 下載第0-N字節范圍的內容
Ranges: bytes=M-N 下載第M-N字節范圍的內容
Ranges: bytes=-N 下載最后N字節內容
If-Range:用於客戶端到服務端的請求,用於判斷實體是否發生改變,必須與Range配合使用。若實體未被修改,則響應所缺少的那部分;否則,響應整個新的實體。
The If-Range HTTP request header makes a range request conditional: if the condition is fulfilled, the range request will be issued and the server sends back a 206 Partial Content answer with the appropriate body. If the condition is not fulfilled, the full resource is sent back, with a 200 OK status.
Accept-Ranges:用於server到client的應答,client通過該自段判斷server是否支持斷點續傳。
Accept-Ranges:bytes 表示支持以bytes為單位進行傳輸。
Accept-Ranges:none 表示不支持斷點續傳
Content-Ranges:用於sever到client的應答,與Accept-Ranges在同一個報文內,通過該字段指定了返回的文件資源的字節范圍。格式如下:
Content-Ranges:bytes M-N/size 大小為size的文件的第M-N字節范圍的內容
關於ETag
ETag用於標識/保證文件的唯一性、完整性,每次文件有更新該值就會變化。
關於HTTP 206
斷點續傳,如果返回文件的一部分,則使用HTTP 206狀態碼;如果返回整個文件,則使用HTTP 200響應碼。
HTTP/1.1 200 OK(不使用斷點續傳)
HTTP/1.1 206 Partial Content(使用斷點續傳)
HTTP/1.1 206 Partial Content
Server: nginx/1.4.2
Date: Fri, 20 Oct 2017 03:28:44 GMT
Content-Type: application/octet-stream
Content-Length: 11
Last-Modified: Tue, 25 Aug 2015 08:56:26 GMT
Connection: keep-alive
ETag: "55dc2dba-14dd5b"
Content-Range: bytes 0-10/1367387
斷點續傳檢查:
curl -i --range 0-9 url 響應中包含Accept-Range或者Content-Ranges則表示支持。
參考:
If-Range:https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/If-Range