Java实现HTTP文件下载(转)

 文章出自: http://www.360doc.com/content/12/1218/17/2718300_254818081.shtml

 

本人用这种方法解决了工作中遇到的问题,再次谢谢文章的作者.

 

 

序言

许多用户可能会遇到这样的情况:在网站上发现一个很好的资源,但是这个资源是分成了很多个文件存放的,如果想把它保存到本地,只有靠用户点击另存来完成保存,如果资源分了几百甚至上千上万,那简直是个灾难。

 

在Internet上很多的资源分成多个文件存放时,它的文件命名是有一定的规则的;正因如此,我们就可以用程序来完成这个资源的完全下载。

1. 基础知识

在Internet上,我们要下载网站上的某个资源,我们会获得一个URL(Uniform Resource Locator),它是一个服务器资源定位的描述,下载的过程总是如下步骤:

步骤1:客户端发起连接请求一个URL

步骤2:服务器解析URL,并将指定的资源返回一个输入流给客户

步骤3:客户端接收输入流,将流中的内容存到文件

2. 网络连接的建立

Java提供了对URL访问和大量的流操作的的API,我们可以很容易的完成对网络上资源的存取,下面的代码段就完成了对一个网站的资源进行访问:

Java代码 复制代码 收藏代码
  1. ......
  2. destUrl="http://www.ebook.com/java/网络编程001.zip";
  3. url = new URL(destUrl);
  4. httpUrl = (HttpURLConnection) url.openConnection();
  5. //连接指定的网络资源
  6. httpUrl.connect();
  7. //获取网络输入流
  8. bis = new BufferedInputStream(httpUrl.getInputStream());
  9. ......
......
destUrl="http://www.ebook.com/java/网络编程001.zip";
url = new URL(destUrl);
httpUrl = (HttpURLConnection) url.openConnection();
//连接指定的网络资源
httpUrl.connect();
//获取网络输入流
bis = new BufferedInputStream(httpUrl.getInputStream());
......

 

3. 代理的访问

  Java 中通过代理服务器访问外网的方法已经是世人皆知的秘密了。这里就不再多描述了,访问的JAVA代码如下:

Java代码 复制代码 收藏代码
  1. //设置代理服务器
  2. System.getProperties().put("proxySet", "true");
  3. System.getProperties().put("proxyHost", "10.154.134.110");
  4. System.getProperties().put("proxyPort", "8080");
//设置代理服务器
System.getProperties().put("proxySet", "true");
System.getProperties().put("proxyHost", "10.154.134.110");
System.getProperties().put("proxyPort", "8080");

 

4. 网络资源的保存

  在上节中,我们已经获取了指定网络资源的输入流,接下来我们要完成的就是读取输入流中的所以内容,并将其保存在文件中。示例代码:

Java代码 复制代码 收藏代码
  1. ......
  2. fos = new FileOutputStream(fileName);
  3. if (this.DEBUG)
  4. System.out.println("正在获取链接[" + destUrl + "]的内容...\n将其保存为文件[" + fileName +"]");
  5.  
  6. //保存文件
  7. while ( (size = bis.read(buf)) != -1)
  8. fos.write(buf, 0, size);
  9. ......  

你可能感兴趣的:(java,文件下载)