http协议从1.1开始支持获取文件的部分内容,这为并行下载以及断点续传提供了技术支持。
它通过在Header里两个参数实现的,客户端发请求时对应的是Range,服务器端响应时对应的是Content-Range;
具体的和Rang有关的http头部信息解释可以参考:https://blog.csdn.net/thewindkee/article/details/80189434
1、对于静态资源的访问,tomcat已经默认支持了断点续传(或者说是并行下载)的功能,允许浏览器一部分一部分
的获取文件内容;实现方法在tomcat的DefaultServlet.java中—静态资源的访问都会交由这个类处理。
2、spring也实现了类似的功能,在ResourceHttpRequestHandler.java中。
3、可以通过在web.xml中的配置,来指定静态资源的访问是由tomcat处理还是spring处理。
4、自定义实现的代码可以参考(这个博客是个断点访问的示例,不是上传,只有进度查看那里和上传有关):https://blog.csdn.net/jsflzhong/article/details/53518458
5、断点上传的代码可以参考:https://blog.csdn.net/jsflzhong/article/details/53518475
原理:
第一次请求:在请求头中设置Range的值,表明请求范围,可以写多个;
第一次响应:服务器在返回的Content-Range信息中会包含已处理的文件部分和总文件大小;
下一次请求:根据上次服务器响应的信息重新设置Range的值;
。。。
对用户而言,可以利用这个方法加快文件的下载速度:
首先指定一个比较小的Rang值,得到文件的总大小
其次,在电脑上开启多个客户端(线程),分别请求文件的不同部分
这样就实现了并行下载。