断点续传下载时http请求

断点续传的原理很简单,就是在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了。
知道了以上原理,就可以进行断点续传的编程了。

你可能感兴趣的:(断点续传下载时http请求)