WEB开发网
开发学院WEB开发Jsp 用Java制作网络文件下载系统 阅读

用Java制作网络文件下载系统

 2008-01-05 19:24:53 来源:WEB开发网   
核心提示:由于linux操作系统的兴起和java语言的日渐成熟,使用Java语言实现一个跨平台的、外观一致的下载工具软件已成为可能,用Java制作网络文件下载系统,网络蚂蚁是大家非常熟知的下载工具软件,我采用Java语言实现了类似网络蚂蚁的基本功能的软件Jants,然后写到文件中 while((nRead=input.read(

  由于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 = new RandomAccessFile("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.保存已经下载的文件的长度值
  
  由于在每次断开连接时都要保存已下载文件的长度,且应进行永久保存,因此将它保存到文件介质中。

Tags:Java 制作 网络

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接