http range 下载大文件分片

上传分片下载也能分
HTTP 协议范围请求允许服务器只发送 HTTP 消息的一部分到客户端。范围请求在传送大的媒体文件,或者与文件下载的断点续传功能搭配使用时非常有用。

检测服务器端是否支持范围请求

假如在响应中存在 Accept-Ranges 首部(并且它的值不为“none”),那么表示该服务器支持范围请求。例如,你可以使用 cURL 发送一个 HEAD 请求来进行检测。

image.png
image.png

从服务器端请求特定的范围

  • 表示第二个500字节:bytes=500-999
  • 表示最后500个字节:bytes=-500
  • 表示500字节以后的范围:bytes=500-
  • 第一个和最后一个字节:bytes=0-0,-1
  • 同时指定几个范围:bytes=500-600,601-999
  • bytes=0- 不限制

成功时服务器返回 206 Partial Content 状态码和 Content-Type:multipart/byteranges; boundary=3d6b6a416f9b5 头部,Content-Type:multipart/byteranges 表示这个响应有多个 byterange。每一部分 byterange 都有他自己的 Content-type 头部和 Content-Range,并且使用 boundary 参数对 body 进行划分。

image.png

只有指定范围的图片被返回

image.png
axios
            .get("http://172.16.8.24:8080/test.png", {
                headers: { "Range": "bytes=0-100000" }, // 字节
                responseType: "arraybuffer",
            })
            .then((res) => {
                console.log(res);
                resolve(res.data);
            })
            .catch((err) => {
                reject(err);
            });

总结

最后把结果拼在一起还待完善~

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 当下载电影时,我常常会想中断下载后,为什么点击开始时会在中断的地方继续下载呢?又或者在看在线电影时,为什么可...
    前端三少爷阅读 362评论 0 0
  • 0.1、索引 https://blog.waterflow.link/articles/1663078266267...
    liuyuede阅读 141评论 0 0
  • 我们知道HTTP报文中的body不仅可以传输文本还可以传输图片、视频以及音频; 随着互联网的发展,现在随便一个HT...
    dashingqi阅读 2,634评论 0 2
  • 先来个总结,我之前和将要写到的文件上传用到的技术和场景描述: 场景描述使用技术图片上传前的预览FileReader...
    CondorHero阅读 3,752评论 0 8
  • 问:如何在有限的带宽下高效快捷地传输大文件? 数据压缩 通常浏览器在发送请求时都会带着“Accept-Encodi...
    编程小王子AAA阅读 884评论 0 0