HTTP Header 中有两个特定用途的 Header,Range & Content-Range。
这两个 Header 的主要作用就是处理断点续传,断点续传即把一个文件的下载行为分成多段下载,如果因为网络或者其它原因导致有部分下载不成功,可以只进行相关分段的重新下载,以节省流量并加快下载速度。
首先是 Range 这个 Header,MDN 介绍如下:https://developer.mozilla.org/en-US/docs/Web/HTTP/Range_requests,该 Header 只可以在 Request 中使用
语法如下:
Range: <unit>=<range-start>-
例:Range: bytes=10- ,表示为从第 11 个字节到最后一个字节
Range: <unit>=<range-start>-<range-end>
例:Range: bytes=100-199,表示为从第 101 个字节到第 200 个字节
Range: <unit>=<range-start>-<range-end>, <range-start>-<range-end>
例:Range: bytes=100-199,200-299 表示同时获取第 101 个字节到 第 200 个字节以及 第 201 个字节到第 300 个字节
Range: <unit>=-<suffix-length>
例:Range: bytes=-100,表示为获取最后 100 个字节
与之对应的是 Content-Range,MDN 介绍如下:https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Range,该 Header 只可以在 Response 中使用
语法如下:
Content-Range: <unit> <range-start>-<range-end>/<size>
我们多在可以获取文件大小的时候使用如下结构
Content-Range: bytes 100-199/5000,表示返回第 101 到第 200 个字节,文件分段长度 200,文件总大小为 5000 字节
同时 HTTP 状态码由常规的 200 变成 206,表示返回的是部分内容
一般下载类库或者工具在使用时,会探测服务方是否支持断点续传,使用如下请求
Range: bytes=0-0
也就是获取第一个字节,如果对方服务器支持断点续传,则会返回
Content-Range: bytes 0-0/5000
HTTP 状态码返回 206
网友评论