最近在研究断点下载(下载续传)的功能,此功能需要服务端和客户端进行对接编写,本篇也是记录一下关于贴上关于实现服务端(Spring Boot)与客户端(Android)是如何实现下载续传功能 断点下载
最近在研究断点下载(下载续传)的功能,此功能需要服务端和客户端进行对接编写,本篇也是记录一下关于贴上关于实现服务端(Spring Boot)与客户端(Android)是如何实现下载续传功能 断点下载功能(下载续传)解释: 客户端由于突然性网络中断等原因,导致的下载失败,这个时候重新下载,可以继续从上次的地方进行下载,而不是重新下载 原理首先,我们先说明了断点续传的功能,实际上的原理比较简单 客户端和服务端规定好一个规则,客户端传递一个参数,告知服务端需要数据从何处开始传输,服务端接收到参数进行处理,之后文件读写流从指定位置开始传输给客户端 实际上,上述的参数,在http协议中已经有规范,参数名为Range 而对于服务端来说,只要处理好Range请求头参数,即可实现下载续传的功能 我们来看下Range请求头数据格式如下: 格式如下:
我们根据上面的格式,服务端对Range字段进行处理(String字符串数据处理),在流中返回指定的数据大小即可 那么,如何让流返回指定的数据大小或从指定位置开始传输数据呢? 这里,Java提供了RandomAccessFile类,通过seekTo()方法,可以让我们将流设置从指定位置开始读取或写入数据 这里读取和写入数据,我是采用的Java7之后新增的NIO的Channel进行流的写入(当然,用传统的文件IO流(BIO)也可以) 这里,我所说的客户端是指的Android客户端,由于App开发也是基于Java,所以也是可以使用RandomAccessFile这个类 对于客户端来说,有以下逻辑: 先读取本地已下载文件的大小,然后请求下载数据将文件大小的数据作为请求头的数值传到服务端,之后也是利用RandomAccessFile移动到文件的指定位置开始写入数据即可 扩展-大文件快速下载思路利用上面的思路,我们还可以可以得到一个大文件快速下载的思路: 如,一份文件,大小为2000B(这个大小可以通过网络请求,从返回数据的请求头content-length获取获取) 客户端拿回到文件的总大小,根据调优算法,将平分成合适的N份,通过线程池,来下载这个N个单文件 在下载完毕之后,将N个文件按照顺序合并成单个文件即可 代码上面说明了具体的思路,那么下面就是贴出服务端和客户端的代码示例 服务端服务端是采用的spring boot进行编写
客户端Android客户端,是基于Okhttp的网络框架写的,需要先引用依赖
下面给出的是封装好的方法(含进度,下载失败和成功回调):
使用:
|
2021-06-05
2021-05-27
2021-05-26
2021-06-05
2021-05-16