断点续传-http中Header参数Range(分段请求基础)


需要用到几个http头

  • range
  • if-range
  • content-range
  • accept-range

断点续传的优缺点

  • 好处:防止大文件下载过程出现网络异常,而前功尽弃。
  • 缺点:要发起多次请求,资源占用大,相对复杂

Range请求头信息介绍

Range

告知服务端,客户端下载该文件想要从指定的位置开始下载,至于 Range 字段属性值的格式有以下几种:

Range主要用来设置获取数据的范围,格式如下:

Range: <unit>=<range-start>-<range-end>
Range: <unit>=<range-start>-<range-end>, <range-start>-<range-end>, <range-start>-<range-end>

<unit> 类型,一般来说是bytes;
<range-start> 表示范围的起始值,一般是数字,如果不是数字就看服务端逻辑如何处理;
<range-end> 表示范围的结束值。这个值是可选的,如果不存在,表示此范围一直延伸到文档结束,如果非数字,同上。

例子

Range:bytes=0-500   
表示下载从0500字节的文件,即头500个字节  ,[0-500]前闭后闭。0<=range<=500 
    
Range:bytes=501-1000
表示下载从5001000这部分的文件,单位字节       

Range:bytes=-500
表示下载最后的500个字节      
     
Range:bytes=500-
表示下载从500开始到文件结束这部分的内容   
 
Range:bytes=500-600,700-1000
表示下载这两个区间的内容

If-Range

If-Range用于判断实体是否发生改变,如果实体未改变,服务器发送客户端丢失的部分,否则发送整个实体.

If-Range 可以使用 Etag 或者Last-Modified 返回的值。当没有 ETag 却有 Last-modified 时,可以把 Last-modified 作为 If-Range 字段的值。
如果请求报文中的 Etag与服务器目标内容的 Etag相等,即没有发生变化,那么应答报文的状态码为 206。如果服务器目标内容发生了变化,那么应答报文的状态码为 200。

在这里插入图片描述

响应头

Content-Range

Content-Range表示响应数据的内容范围,语法格式如下:

Content-Range: <unit> <range-start>-<range-end>/<size>Content-Range: <unit> <range-start>-<range-end>/*Content-Range: <unit> */<size>
<unit> 类型,一般来说是bytes;
<range-start> 区间的起始值;
<range-end> 区间的结束值;
<size> 整个文件的大小(如果大小未知则用 "*" 表示)

例子

Content-Range:bytes 501-1000/2000
#501-100 请求头里range的值
#2000 文件总大小
#bytes 字节方式

Last-Modified:表示资源最近修改的时间(分段下载时要注意这个东西,因为如果修改了,分段下载可能就要重新下载了)
ETag:这个响应头表示资源版本的标识符,通常是消息摘要(类似MD5一样)(分段下载时要注意这个东西,或者缓存控制也要注意这个东西)
注意,每种服务器对生成ETag的算法不同,这个要特别注意 如果使用分布式缓存,要特别要保证每台服务器生成的ETag算法是一致的.
缓存的过期,要同时结合(ETag + Last-Modified)这两个响应头来判断.
强ETag
只要实体发生任何改变,都会改变ETag值.如:
ETag: "1234234234"
弱ETag
它在前面会有个W/,如:
ETag: W/"12342423"

Accept-Ranges

Accept-Ranges用于服务器响应,告诉浏览器是否支持Range
语法:

Accept-Ranges: bytesAccept-Ranges: none
  • none不支持任何范围请求单位,由于其等同于没有返回此头部,因此很少使用。不过一些浏览器,比如IE9,会依据该头部去禁用或者移除下载管理器的暂停按钮;
  • bytes 一般情况
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值