java断点续传
2016-04-13 00:00
274 查看
摘要: java断点续传
断点续传的原理
其实断点续传的原理很简单,就是在 Http 的请求上和一般的下载有所不同而已。打个比方,浏览器请求服务器上的一个文时,所发出的请求如下:假设服务器域名为 wwww.sjtu.edu.cn,文件名为 down.zip。GET /down.zip HTTP/1.1Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/vnd.ms-excel, application/msword, application/vnd.ms-powerpoint, */*Accept-Language: zh-cnAccept-Encoding: gzip, deflateUser-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)Connection: Keep-Alive服务器收到请求后,按要求寻找请求的文件,提取文件的信息,然后返回给浏览器,返回信息如下:200Content-Length=106786028Accept-Ranges=bytesDate=Mon, 30 Apr 2001 12:56:11 GMTETag=W/"02ca57e173c11:95b"Content-Type=application/octet-streamServer=Microsoft-IIS/5.0Last-Modified=Mon, 30 Apr 2001 12:56:11 GMT所谓断点续传,也就是要从文件已经下载的地方开始继续下载。所以在客户端浏览器传给 Web 服务器的时候要多加一条信息 -- 从哪里开始。下面是用自己编的一个"浏览器"来传递请求信息给 Web 服务器,要求从 2000070 字节开始。GET /down.zip HTTP/1.0User-Agent: NetFoxRANGE: bytes=2000070-Accept: text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2仔细看一下就会发现多了一行 RANGE: bytes=2000070-这一行的意思就是告诉服务器 down.zip 这个文件从 2000070 字节开始传,前面的字节不用传了。服务器收到这个请求以后,返回的信息如下:206Content-Length=106786028Content-Range=bytes 2000070-106786027/106786028Date=Mon, 30 Apr 2001 12:55:20 GMTETag=W/"02ca57e173c11:95b"Content-Type=application/octet-streamServer=Microsoft-IIS/5.0Last-Modified=Mon, 30 Apr 2001 12:55:20 GMT和前面服务器返回的信息比较一下,就会发现增加了一行:Content-Range=bytes 2000070-106786027/106786028返回的代码也改为 206 了,而不再是 200 了。知道了以上原理,就可以进行断点续传的编程了。Java 实现断点续传的关键几点
(1) 用什么方法实现提交 RANGE: bytes=2000070-。当然用最原始的 Socket 是肯定能完成的,不过那样太费事了,其实 Java 的 net 包中提供了这种功能。代码如下:URL url = new URL("http://www.sjtu.edu.cn/down.zip");HttpURLConnection httpConnection = (HttpURLConnection)url.openConnection();// 设置 User-AgenthttpConnection.setRequestProperty("User-Agent","NetFox");// 设置断点续传的开始位置httpConnection.setRequestProperty("RANGE","bytes=2000070");// 获得输入流InputStream input = httpConnection.getInputStream();从输入流中取出的字节流就是 down.zip 文件从 2000070 开始的字节流。大家看,其实断点续传用 Java 实现起来还是很简单的吧。接下来要做的事就是怎么保存获得的流到文件中去了。保存文件采用的方法。我采用的是 IO 包中的 RandAccessFile 类。操作相当简单,假设从 2000070 处开始保存文件,代码如下:RandomAccess oSavedFile = new RandomAccessFile("down.zip","rw");long nPos = 2000070;// 定位文件指针到 nPos 位置oSavedFile.seek(nPos);byte[] b = new byte[1024];int nRead;// 从输入流中读入字节流,然后写到文件中while((nRead=input.read(b,0,1024)) > 0){oSavedFile.write(b,0,nRead);}相关文章推荐
- java断点续传原理
- java实现断点续传
- java断点续传原理
- java实现断点续传
- java断点续传demo
- java实现多线程断点续传
- JDK动态代理和cglib的动态代理
- Scala&Java实现快速排序
- Hadoop序列化&Java序列化
- Java异常处理
- 第五章 征服数据库(Spring对DB的使用)——开发持久层
- 为什么一个java源文件中只能有一个public类?
- Java异常处理throws,throw关键字try,catch,finally模块
- java自动装箱和拆箱机制详解
- eclipse下Struts2配置文件添加自动提示
- JAVA学习之基础语法练习--彩票(二)
- Eclipse 安装反编译插件jadclipse(经验总结)
- 编译、运行有包的java源文件
- java简单算法(二分查找 冒泡排序 判断是否为素数)
- java正则表达式解析短信模板