先说说断点续传的原理:这是HTTP 1.1协议的一部分,并不需要客户端特意去做多么复杂的事情。以前我曾经看过一个单位的技术标书,其中有下载的断点续传这一要求,给出的offer居然还挺高的...
简单的说,只要利用了HTTP协议(http://www.ietf.org/rfc/rfc2616.txt)中的如下字段来和服务器端交互,就可以实现文件下载的断点续传:
Range : 用于客户端到服务器端的请求,可通过该字段指定下载文件的某一段大小,及其单位。典型的格式如:
Range: bytes=0-499 下载第0-499字节范围的内容
Range: bytes=500-999 下载第500-999字节范围的内容
Range: bytes=-500 下载最后500字节的内容
Range: bytes=500- 下载从第500字节开始到文件结束部分的内容(这是最常用的一种格式)
Range: bytes=0-0,-1 下载第一以及最后一个字节的内容(这个看上去有点变态...)
Accept-Ranges : 用于服务器端到客户端的应答,客户端通过该字段可以判断服务器是否支持断点续传(注意RFC中注明了这一部分并不是必须的)。格式如下:
Accept-Ranges: bytes 表示支持以bytes为单位进行传输。
Accept-Ranges: none 表示不支持
Content-Ranges : 用于服务器端到客户端的应答,与Accept-Ranges在同一个报文内,通过该字段指定了返回的文件资源的字节范围。格式如下:
Content-Ranges: bytes 0-499/1234 大小为1234的文件的第0-499字节范围的内容
Content-Ranges: bytes 734-1233/1234 大小为1234字节的文件的第734-结尾范围的内容
据此我们可以知道,断点续传这个功能是需要客户端和服务器端同时支持才能完成。
Android平台面向开发者提供了DownloadManager这个服务(service),可以用来完成下载,同时异步地得到下载进度的实时更新提示。原生的浏览器,Android Market以及GMail等客户端都使用了该接口。该接口也部分的提供了断点续传功能:如果在下载过程中遇到网络错误,如信号中断等,DownloadManager会在网络恢复时尝试断点续传继续下载该文件。但不支持由用户发起的暂停然后断点续传。
要扩展该功能也不难,只要为下载任务新增一种状态(类似paused_by_user),以及相关逻辑即可,这里暂不赘述,把话题引到一些常见问题上。
1. 关于ETag
RFC中的定义有些抽象,简单的说,ETag可以用来标识/保证文件的唯一性或完整性,你可以把它看作是服务器为某个文件生产的唯一标识值,每次文件有更新该值就会变化。通过这种机制客户端可以检查某个文件在断点续传(当然它不仅仅用于断点续传)的前后是否有所改动:如果ETag改变了就应该重新下载整个文件以保证它的完整性。
但是在现实环境中,有一些服务器并不返回ETag字段,同时它又是支持断点续传的,这种情况下原生的Android就会认为服务器端不支持断点续传。这应该不是什么bug,仅仅是这么实现而已。还有更麻烦的情况是,有些服务器给了错误的ETag,但文件是从未更改的,这时候要想从客户端修改这个“bug”,估计只能忽略ETag值了。
2. 关于HTTP 206
RFC中定义了断点续传时服务器端的应答情况:如果支持且返回的内容如请求所要求的那样,是该文件的一部分,则使用HTTP 206状态码;如果不支持,或需要返回整个文件,则使用HTTP 200状态码。但是现实网络中有些服务器不管三七二十一,都返回200。没办法,如果还是想从客户端来修改这个“bug”,那就多做一些判断处理吧:如果服务器指定了“Content-Ranges”,就忽略HTTP 200的状态码。
附图一张,简述流程。见附件
补记:有一次被问起如何在原生的Android手机上暂停一个下载任务,回头再断点续传。我想是不是可以在下载过程中将手机信号关闭,下次再打开手机信号时,那个下载任务就可以自动接着续传了(当然前提是服务器支持)...这个用例没多大实用价值,懒得实测了
- 大小: 14.9 KB
分享到:
相关推荐
Java 断点续传技术是网络传输中常用的一种机制,特别是在大文件下载或上传时,如果因为网络中断或其他原因导致传输失败,可以借助断点续传功能从上次中断的地方继续,而无需重新开始。在Java中实现断点续传,通常...
Java 断点续传的原理主要涉及到网络编程、文件处理以及多线程技术。断点续传是指在上传或下载大文件时,如果因为网络中断或其他原因导致传输不完整,可以从上次中断的地方继续传输,而不需要从头开始,极大地提高了...
Java 断点续传上传是一种在文件传输过程中,如果因为网络中断或其他原因导致传输不完整,可以从上次中断的位置继续上传的技术。这种技术尤其在大文件传输时非常有用,避免了因网络问题而需要重新上传整个文件的困扰...
综上所述,Java断点续传技术涉及网络编程、文件操作和异常处理等多个方面,通过合理的实现可以显著提高大文件下载的效率和用户体验。理解并掌握这些知识点对于开发高效的文件下载应用至关重要。
### 文件断点续传原理与实现 #### 一、引言 在互联网应用日益广泛的今天,文件传输成为了不可或缺的一部分。然而,在实际应用中经常会遇到网络不稳定的情况,这导致了文件传输过程中可能出现中断的问题。为了解决这...
【Java 断点续传原理与实现】 Java 断点续传是一种在文件传输过程中,如果因为网络中断或其他原因导致传输不完整,可以从上次中断的位置继续下载的技术。它主要依赖于HTTP协议中的Range头字段来实现。以下是实现...
开发者可以通过研究这些代码来深入理解断点续传的工作原理,并在自己的项目中应用这些技术。无论是服务端还是客户端的断点续传,都需要对HTTP协议有深入的理解,尤其是HTTP头的使用,以及对文件操作和网络编程的熟悉...
### 用Java实现断点续传的技术解析 #### 一、技术原理概述 断点续传是一种在网络连接不稳定或在下载过程中出现意外中断时能够继续完成下载的技术。它通过记录下载过程中断时的位置,当重新启动下载任务时,可以从...
### 断点续传的原理 断点续传的基本思想是:当文件下载到一定程度时发生中断,则在下次下载时可以从已下载的部分之后继续下载剩余部分,而不是从头开始下载。这一过程涉及到了服务器与客户端之间的通信协议,尤其是...
- **源代码**:包括Java源文件,实现了FastDFS的客户端和服务器端接口,以及断点续传的逻辑。 - **配置文件**:如`fastdfs_client.conf`,用于配置FastDFS客户端连接参数。 - **测试用例**:可能包含单元测试或...
【断点续传的原理】 断点续传是一种在文件传输过程中常见的技术,特别是在网络环境不稳定或者文件体积庞大的情况下。其基本原理是通过保存已经下载的部分文件信息,当因网络中断或其他原因导致传输中断后,可以从已...
标题中的“socket做的支持多线程断点上传or断点续传Java源码”涉及到的是在网络编程中,如何使用Java的Socket API实现一个能够处理断点上传和断点续传功能的服务。这是一个高级的网络编程任务,通常在大型文件传输...
对于开发者来说,理解FastDFS的工作原理和API使用,以及如何在代码层面实现断点续传的逻辑,是非常关键的技能。在实际项目中,可以结合具体的业务需求和环境进行优化,例如使用异步上传、多线程处理等技术进一步提升...
总的来说,FTP及断点续传原理是网络开发和运维中的基础技能,了解和掌握这些知识对于进行文件传输相关的系统设计和故障排查至关重要。通过学习提供的资源,你可以深入理解FTP的工作机制,以及如何实现断点续传功能,...
一、断点续传原理 断点续传基于HTTP协议的Range请求头。当客户端(例如Java应用)希望恢复中断的下载时,它会发送一个带有特定Range头的HTTP GET请求,告知服务器从哪个位置开始继续传输数据。服务器接收到这个请求...