由于Linux操作系统的兴起和Java语言的日渐成熟,使用Java语言实现一个跨平台的、外观一致的下载工具软件已成为可能。网络蚂蚁是大家非常熟知的下载工具软件,我采用Java语言实现了类似网络蚂蚁的基本功能的软件Jants。本文介绍了一些技术实现要点。
单线程直接获取网络文件
单线程直接获取网络文件的要害点是获取网络文件,以确定基本方法的正确性。它的初始代码的内容比较简单,可以利用HTTP的基本知识进行设计。它的基本原理是:连接网络地址,打开连接并获取输入流,从输入流中读取数据。实现代码(测试过程中使用的)如下:
int data;//从输入流中获取数据
URL url=new URL("http://www.sohu.com");
//创建连接的地址
HttpURLConnection connection=url.openConnection();
//打开连接
int responsCode=connection. getResponseCode();
//返回Http的响应状态码
InputStream input=connection.getInputStream();
//获取输入流
System.out.println("responseCode:"+responseCode);
While((data=input.read())!=-1)
System.out.println(data);
//将获取的数据打到屏幕显示出来
单线程断点续传
大家经常有这样的体会:下载一个几十兆的文件时忽然断线,结果前功尽弃。可以使用断点续传解决这个问题。
基本原理
这里主要介绍一下断点续传的原理。断点续传的原理很简单,只是在HTTP请求上和一般的下载有所不同。
所谓断点续传,也就是要从文件已经下载的地方开始继续下载。所以,在客户端传给Web服务器的时候,要多加一条信息——下载的起始位置,且服务器返回的HTTP状态代码也从200转变为206。
上述要点,可以使用Java语言中的HttpURLConnection类中的setRequestProperty()方法来设置。
断点续传的要害步骤
1.实现提交断点续传下载的起始位置
Java的Net包中提供了这种功能,代码如下:
URL url = new URL("http://www.mydomain.com/down.zip";);
HttpURLConnection httpConnection=(HttpURLConnection) url.openConnection();
//设置断点续传的开始位置
httpConnection.setRequestProperty("RANGE","bytes=10000");
//设置请求信息
httpConnection.setRequestProperty("GET","/down.zip HTTP/1.1");
//设置接受信息
httpConnection.setRequestProperty("Accept","image/gif,image/x-xbitmap,application/
msWord,*/*");
//设置连接信息
httpConnection.setRequestProperty("Connection","Keep-Alive");
//获得输入流
InputStream input = httpConnection.getInputStream();
从输入流中取出的字节流,就是down.zip文件从10000字节开始的字节流。
2.保存获得的字节流到文件中
由于文件的下载涉及到断点续传,因此,在保存文件的时候,需要对文件进行随机读写。非凡是在多线程下载的过程中,需要在写文件之前在文件中定位。
在Java的IO包中的RandomAccessFile类可以满足这种设计需求。该类在文件中定位指针时,用到的方法是seek(Long)。
操作相当简单。假设从10000字节处开始保存文件,代码如下:
RandomAccess oSavedFile = newRandomAccessFile("down.zip","rw");
//创建随机文件
long nPos = 10000;
//定位文件指针到nPos位置
oSavedFile.seek(nPos);
byte[] b = new byte[1024];
int nRead;
//从输入流中读入字节流,然后写到文件中
while((nRead=input.read(b,0,1024)) 0)
{ //input为网络输入流
oSavedFile.write(b,0,nRead);
}
3.保存已经下载的文件的长度值
由于在每次断开连接时都要保存已下载文件的长度,且应进行永久保存,因此将它保存到文件介质中。