学院首页>网络编程>JSP>用Java实现断点续传(HTTP)

用Java实现断点续传(HTTP)

作者: 来源: 添加时间:2006-5-24 13:02:07



  (三)断点续传内核的实现
  主要用了6个类,包括一个测试类。
  SiteFileFetch.java负责整个文件的抓取,控制内部线程(FileSplitterFetch类)。
  FileSplitterFetch.java负责部分文件的抓取。
  FileAccess.java负责文件的存储。
  SiteInfoBean.java要抓取的文件的信息,如文件保存的目录,名字,抓取文件的URL等。
  Utility.java工具类,放一些简单的方法。
  TestMethod.java测试类。


  下面是源程序:
  /*
  **SiteFileFetch.java
  */
  package NetFox;
  import java.io.*;
  import java.net.*;


  public class SiteFileFetch extends Thread {


  SiteInfoBean siteInfoBean = null; //文件信息Bean
  long[] nStartPos; //开始位置
  long[] nEndPos; //结束位置
  FileSplitterFetch[] fileSplitterFetch; //子线程对象
  long nFileLength; //文件长度
  boolean bFirst = true; //是否第一次取文件
  boolean bStop = false; //停止标志
  File tmpFile; //文件下载的临时信息
  DataOutputStream output; //输出到文件的输出流


  public SiteFileFetch(SiteInfoBean bean) throws IOException
  {
  siteInfoBean = bean;
  //tmpFile = File.createTempFile ("zhong","1111",new File(bean.getSFilePath()));
  tmpFile = new File(bean.getSFilePath()+File.separator + bean.getSFileName()+".info");
  if(tmpFile.exists ())
  {
  bFirst = false;
  read_nPos();
  }
  else
  {
  nStartPos = new long[bean.getNSplitter()];
  nEndPos = new long[bean.getNSplitter()];
  }



  }


  public void run()
  {
  //获得文件长度
  //分割文件
  //实例FileSplitterFetch
  //启动FileSplitterFetch线程
  //等待子线程返回
  try{
  if(bFirst)
  {
  nFileLength = getFileSize();
  if(nFileLength == -1)
  {
  System.err.println("File Length is not known!");
  }
  else if(nFileLength == -2)
  {
  System.err.println("File is not access!");
  }
  else
  {
  for(int i=0;i<nStartPos.length;i++)
  {
  nStartPos[i] = (long)(i*(nFileLength/nStartPos.length));
  }
  for(int i=0;i<nEndPos.length-1;i++)
  {
  nEndPos[i] = nStartPos[i+1];
  }
  nEndPos[nEndPos.length-1] = nFileLength;
  }
  }


  //启动子线程
  fileSplitterFetch = new FileSplitterFetch[nStartPos.length];
  for(int i=0;i<nStartPos.length;i++)
  {
  fileSplitterFetch[i] = new FileSplitterFetch(siteInfoBean.getSSiteURL(),
  siteInfoBean.getSFilePath() + File.separator + siteInfoBean.getSFileName(),
  nStartPos[i],nEndPos[i],i);
  Utility.log("Thread " + i + " , nStartPos = " + nStartPos[i] + ", nEndPos = " + nEndPos[i]);
  fileSplitterFetch[i].start();
  }
  // fileSplitterFetch[nPos.length-1] = new FileSplitterFetch(siteInfoBean.getSSiteURL(),
  siteInfoBean.getSFilePath() + File.separator + siteInfoBean.getSFileName(),nPos[nPos.length-1],nFileLength,nPos.length-1);
  // Utility.log("Thread " + (nPos.length-1) + " , nStartPos = " + nPos[nPos.length-1] + ",
  nEndPos = " + nFileLength);
  // fileSplitterFetch[nPos.length-1].start();


  //等待子线程结束
  //int count = 0;
  //是否结束while循环
  boolean breakWhile = false;


  while(!bStop)
  {
  write_nPos();
  Utility.sleep(500);
  breakWhile = true;


  for(int i=0;i<nStartPos.length;i++)
  {
  if(!fileSplitterFetch[i].bDownOver)
  {
  breakWhile = false;
  break;
  }
  }
  if(breakWhile)
  break;


  //count++;
  //if(count>4)
  // siteStop();
  }


  System.err.println("文件下载结束!");
  }
  catch(Exception e){e.printStackTrace ();}
  }

第 2 页,共 2 页 [1] [2]
站内搜索