断点续传之前我们首先需要了解http协议
断点续传简单的说,就是接着上一次的已经下载好的位置接着下载文件,如何接着以前已经下载的位置接着下载,这是我们要解决的问题.
http header详解参考http://www.cnblogs.com/xyxiong/archive/2011/08/19/2145869.html。
解释其中几个用到的属性:
Range : 用于客户端到服务器端的请求,可通过该字段指定下载文件的某一段大小,及其单位。典型的格式如:
Range: bytes=0-499 下载第0-499字节范围的内容
Range: bytes=500-999 下载第500-999字节范围的内容
Range: bytes=-500 下载最后500字节的内容
Range: bytes=500- 下载从第500字节开始到文件结束部分的内容
客户端请求:
httpURLConnection.setRequestProperty("Range", "bytes="+12+"-");
服务器响应:
Accept-Ranges : 用于服务器端到客户端的应答,客户端通过该字段可以判断服务器是否支持断点续传
Accept-Ranges: bytes 表示支持以bytes为单位进行传输。
Accept-Ranges: none 表示不支持Content-Ranges : 用于服务器端到客户端的应答,与Accept-Ranges在同一个报文内,通过该字段指定了返回的文件资源的字节范围。格式如下:
Content-Ranges: bytes 0-500/1234 大小为1234的文件的第0-500字节范围的内容
Content-Ranges: bytes 500-1233/1234 大小为1234字节的文件的第500-结尾范围的内容ETag:简单的说,ETag可以用来标识/保证文件的唯一性或完整性,你可以把它看作是服务器为某个文件生产的唯一标识值,每次文件有更新该值就会变化。通过这种机制客户端可以检查某个文件在断点续传(当然它不仅仅用于断点续传)的前后是否有所改动:如果ETag改变了就应该重新下载整个文件以保证它的完整性
String etag = httpURLConnection.getHeaderField("ETag"); String acceptRange= httpURLConnection.getHeaderField("Accept-Ranges"); String contentRange = httpURLConnection.getHeaderField("content-range");
知道这些之后就可以通过RandomAccessFile类进行断点续传了。
来源:oschina
链接:https://my.oschina.net/u/141149/blog/55337