实现下载指定URL的网上资源

ava实现多线程多节点非断点下载网上资源(以后可以不用迅雷了,嘿嘿)
。。。断点功能尚未实现。。。目前可以下载大部分的软件或者文件,网上随便找了一个图片。。。得到它的URL: http://photo.jokeji.cn/UpFilesnew/2011/5/24/2011524223829861.gif,如下代码即是实现下载该搞笑图片。。。
标签: <无>

代码片段(1)

[代码] [Java]代码

001import java.io.*;
002import java.net.*;
003//定义下载从start到end的内容的线程
004class DownThread extends Thread
005{
006 //定义字节数组(取水的竹筒)的长度
007 private final int BUFF_LEN = 32;
008 //定义下载的起始点
009 private long start;
010 //定义下载的结束点
011 private long end;
012 //下载资源对应的输入流
013 private InputStream is;
014 //将下载到的字节输出到raf中
015 private RandomAccessFile raf ;
016 //构造器,传入输入流,输出流和下载起始点、结束点
017 public DownThread(long start , long end
018  , InputStream is , RandomAccessFile raf)
019 {
020  //输出该线程负责下载的字节位置
021  System.out.println(start + "---->"  + end);
022  this.start = start;
023  this.end = end;
024  this.is = is;
025  this.raf = raf;
026 }
027 public void run()
028 {
029  try
030  {
031   is.skip(start);
032   raf.seek(start);
033   //定义读取输入流内容的的缓存数组(竹筒)
034   byte[] buff = new byte[BUFF_LEN];
035   //本线程负责下载资源的大小
036   long contentLen = end - start;
037   //定义最多需要读取几次就可以完成本线程的下载
038   long times = contentLen / BUFF_LEN + 4;
039   //实际读取的字节数
040   int hasRead = 0;
041   for (int i = 0; i < times ; i++)
042   {
043    hasRead = is.read(buff);
044    //如果读取的字节数小于0,则退出循环!
045    if (hasRead < 0)
046    {
047     break;
048    }
049    raf.write(buff , 0 , hasRead);
050   }  
051  }
052  catch (Exception ex)
053  {
054   ex.printStackTrace();
055  }
056  //使用finally块来关闭当前线程的输入流、输出流
057  finally
058  {
059   try
060   {
061    if (is != null)
062    {
063     is.close();
064    }
065    if (raf != null)
066    {
067     raf.close();
068    }
069   }
070   catch (Exception ex)
071   {
072    ex.printStackTrace();
073   }
074  }
075 }
076}
077public class MutilDown
078{
079 public static void main(String[] args)
080 {
081  final int DOWN_THREAD_NUM = 4;
082  final String OUT_FILE_NAME = "down.jpg";
083  InputStream[] isArr = new InputStream[DOWN_THREAD_NUM];
084  RandomAccessFile[] outArr = new RandomAccessFile[DOWN_THREAD_NUM];
085  try
086  {
087   //创建一个URL对象
088   URL url = new URL("http://photo.jokeji.cn/"
089    + "UpFilesnew/2011/5/24/2011524223829861.gif");
090   //以此URL对象打开第一个输入流
091   isArr[0] = url.openStream();
092   long fileLen = getFileLength(url);
093   System.out.println("网络资源的大小" + fileLen);
094   //以输出文件名创建第一个RandomAccessFile输出流
095   outArr[0] = new RandomAccessFile(OUT_FILE_NAME , "rw");
096   //创建一个与下载资源相同大小的空文件
097   for (int i = 0 ; i < fileLen ; i++ )
098   {
099    outArr[0].write(0);
100   }
101   //每线程应该下载的字节数
102   long numPerThred = fileLen / DOWN_THREAD_NUM;
103   //整个下载资源整除后剩下的余数
104   long left = fileLen % DOWN_THREAD_NUM;
105   for (int i = 0 ; i < DOWN_THREAD_NUM; i++)
106   {
107    //为每个线程打开一个输入流、一个RandomAccessFile对象,
108    //让每个线程分别负责下载资源的不同部分。
109    if (i != 0)
110    {
111     //以URL打开多个输入流
112     isArr[i] = url.openStream();
113     //以指定输出文件创建多个RandomAccessFile对象
114     outArr[i] = new RandomAccessFile(OUT_FILE_NAME , "rw");
115    }
116    //分别启动多个线程来下载网络资源
117    if (i == DOWN_THREAD_NUM - 1 )
118    {
119     //最后一个线程下载指定numPerThred+left个字节
120     new DownThread(i * numPerThred , (i + 1) * numPerThred + left
121      , isArr[i] , outArr[i]).start();
122    }
123    else
124    {
125     //每个线程负责下载一定的numPerThred个字节
126     new DownThread(i * numPerThred , (i + 1) * numPerThred
127      , isArr[i] , outArr[i]).start();
128    }
129   }
130  }
131  catch (Exception ex)
132  {
133   ex.printStackTrace();
134  }
135 }
136 //定义获取指定网络资源的长度的方法
137 public static long getFileLength(URL url) throws Exception
138 {
139  long length = 0;
140  //打开该URL对应的URLConnection。
141  URLConnection con = url.openConnection();
142  //获取连接URL资源的长度
143  long size = con.getContentLength();
144  length = size;
145  return length;
146 }
147}
148  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值