断点续传的原理很简单,就是在Http的请求上和一般的下载有所不同而已。注:需要web容器的支持,现在绝大多数都支持此项
以例子说明断点续传。
例如使用本地的服务器127.0.0.1,文件名为data.zip。下载该文件所发出的头信息如下:
GET /data.zip HTTP/1.1
Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/vnd.ms-excel, application/msword, application/vnd.ms-powerpoint, */*
Accept-Language: zh-cn
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)
Connection: Keep-Alive
在服务器端接收到请求后,会按要求寻找请求的文件,并提取文件的信息,然后返回给浏览器,返回信息如下:
200
Content-Length=105555555
Accept-Ranges=bytes
Date=Sun, 28 Aug 2012 10:56:16 GMT
ETag=W/"031a54e173c11:df5"
Content-Type=application/octet-stream
Server=Apache/1.3.14(Unix)
Last-Modified= Sun, 28 Aug 2012 10:56:16 GMT
断点续传,就是要将文件从已经下载的地方开始,继续下载。所在客户端在发给服务器的信息中,要指明下载开始的地方。
下面是用自己模拟一个"浏览器"来传递请求信息给Web服务器,要求从20120828字节开始。
GET /data.zip HTTP/1.0
User-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)RANGE: bytes=20120828-
请仔细查看一下,就会发现上面多了一行RANGE: bytes=20120828- 的信息
这一行的意思是告诉服务器下载data.zip这个文件从20120828字节开始传,前面的字节就不需要用传了。
服务器收到这个请求以后,返回的信息如下:
206
Content-Length=105555555
Content-Range=bytes 20120828-105555554/105555555
Date= Sun, 28 Aug 2012 11:04:18 GMT
ETag=W/"031a54e173c11:df5"
Content-Type=application/octet-stream
Server=Apache/1.3.14(Unix)
Last-Modified= Sun, 28 Aug 2012 10:56:16 GMT
和前面服务器返回的信息比较一下,就会发现增加了一行:
Content-Range=bytes 20120828-10555554/10555555
返回的代码也改为206了,而不再是200了。
知道了以上原理,就可以进行断点续传的编程了。