学习log4j时碰到一个下载的 贴过来留着用^_^
import java.io.BufferedInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.Vector;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* <p>Title: HttpDownFile</p>
* <p>Description: 将指定的HTTP网络资源在本地以文件形式存放</p>
* <p>Copyright: Copyright (c) 2006</p>
* <p>Company: </p>
* @author
* @version 1.0
*/
public class HttpDownFile {
public final static boolean DEBUG = true; //调试用
private static int BUFFER_SIZE = 8096; //缓冲区大小
private Vector vDownLoad = new Vector(); //URL列表
private Vector vFileList = new Vector(); //下载后的保存文件名列表
/**
* LOG日志对象
*/
private static final Log logger = LogFactory.getLog(HttpDownFile.class);
/**
* 构造方法
*/
public HttpDownFile() {
}
/**
* 清除下载列表
*/
public void resetList() {
vDownLoad.clear();
vFileList.clear();
}
/**
* 增加下载列表项
*
* @param url String
* @param filename String
*/
public void addItem(String url, String filename) {
vDownLoad.add(url);
vFileList.add(filename);
}
/**
* 根据列表下载资源
*/
public void downLoadByList() {
String url = null;
String filename = null;
//按列表顺序保存资源
for (int i = 0; i < vDownLoad.size(); i++) {
url = (String) vDownLoad.get(i);
filename = (String) vFileList.get(i);
try {
saveToFile(url, filename);
} catch (IOException err) {
logger.info(err);
logger.info(err.getMessage());
if (DEBUG) {
logger.info("资源[" + url + "]下载失败!!!");
}
}
}
if (DEBUG) {
logger.info("下载完成!!!");
}
}
/**
* 将HTTP资源另存为文件
*
* @param destUrl String
* @param fileName String
* @throws Exception
*/
public void saveToFile(String destUrl, String fileName) throws IOException {
FileOutputStream fos = null;
BufferedInputStream bis = null;
HttpURLConnection httpUrl = null;
URL url = null;
byte[] buf = new byte[BUFFER_SIZE];
int size = 0;
//建立链接
url = new URL(destUrl);
httpUrl = (HttpURLConnection) url.openConnection();
//连接指定的资源
httpUrl.connect();
//获取网络输入流
bis = new BufferedInputStream(httpUrl.getInputStream());
//建立文件
fos = new FileOutputStream(fileName);
if (this.DEBUG)
logger.info("正在获取链接[" + destUrl + "]的内容.../n将其保存为文件[" + fileName + "]");
//保存文件
while ((size = bis.read(buf)) != -1)
fos.write(buf, 0, size);
fos.close();
bis.close();
httpUrl.disconnect();
}
/**
* 设置代理服务器
*
* @param proxy String
* @param proxyPort String
*/
public void setProxyServer(String proxy, String proxyPort) {
//设置代理服务器
System.getProperties().put("proxySet", "true");
System.getProperties().put("proxyHost", proxy);
System.getProperties().put("proxyPort", proxyPort);
}
/**
* 设置认证用户名与密码
*
* @param uid String
* @param pwd String
*/
public void setAuthenticator(String uid, String pwd) {
// Authenticator.setDefault(new MyAuthenticator(uid, pwd));
}
/**
* 主方法(用于测试)
*
* @param argv String[]
*/
public static void main(String argv[]) {
HttpDownFile oInstance = new HttpDownFile();
try {
//增加下载列表(此处用户可以写入自己代码来增加下载列表),下载文件保存在当前目录下。
oInstance.addItem(
"http://image2.sina.com.cn/home/images/sina_logo2.gif",
"./yxdcb_1.gif");
oInstance.addItem(
"http://img.blog.163.com/photo/zMI7G40BAJnh8WNUyZ6VTQ==/5713097602297097808.jpg",
"./yxdcb_2.jpg");
//开始下载
oInstance.downLoadByList();
} catch (Exception err) {
logger.info(err.getMessage());
}
}
}