序言
许多用户可能会遇到这样的情况:在网站上发现一个很好的资源,但是这个资源是分成了很多个文件存放的,如果想把它保存到本地,只有靠用户点击另存来完成保存,如果资源分了几百甚至上千上万,那简直是个灾难。
在Internet上很多的资源分成多个文件存放时,它的文件命名是有一定的规则的;正因如此,我们就可以用程序来完成这个资源的完全下载。
1. 基础知识
在Internet上,我们要下载网站上的某个资源,我们会获得一个URL(Uniform Resource Locator),它是一个服务器资源定位的描述,下载的过程总是如下步骤:
url = new URL(destUrl); httpUrl = (HttpURLConnection) url.openConnection(); //连接指定的网络资源 httpUrl.connect(); //获取网络输入流 bis = new BufferedInputStream(httpUrl.getInputStream()); ...... |
//设置代理服务器 System.getProperties().put("proxySet", "true"); System.getProperties().put("proxyHost", "10.154.134.110"); System.getProperties().put("proxyPort", "8080"); |
...... fos = new FileOutputStream(fileName); if (this.DEBUG) System.out.println("正在获取链接[" + destUrl + "]的内容...\n将其保存为文件[" + fileName +"]"); //保存文件 while ( (size = bis.read(buf)) != -1) fos.write(buf, 0, size); ...... |
上面的示例代码就将网络资源的内容保存到了本地指定的文件中。
5. 代码清单 Title: 个人开发的API Description: 将指定的HTTP网络资源在本地以文件形式存放 Copyright: Copyright (c) 2004 Company: NewSkyimport java.io.*;import java.net.*;import java.util.*;/** *
下载源代码