总结:根据指定地址下载文件/下载压缩包以及解压文件
1.下载文件/下载压缩包方法
import java.io.*;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
/*
* 下载文件
* @param urlPath:指定下载的链接【例如:http://xxx.xxx.xxx......】
* @param downloadDir:指定文件存放的地址前缀【例如:/home/xxx/】
*/
private void downloadFile(String urlPath,String downloadDir){
File file = null;
String path = "";
try{
// 统一资源
URL url = new URL(urlPath);
// 连接类的父类,抽象类
URLConnection urlConnection = url.openConnection();
// http的连接类
HttpURLConnection httpURLConnection = (HttpURLConnection) urlConnection;
// 设置超时时间 6s
HttpURLConnection.setConnectTimeout(6*1000);
// 设置请求方式,默认是GET
httpURLConnection.setRequestMethod("GET");
// 设置字符编码
httpURLConnection.setRequestProperty("Charset","UTF-8");
// 打开到此,URL引用资源的通信连接(如果尚未建立这样的连接)
httpURLConnection.connect();
// 文件大小
int fileLength = httpURLConnection.getContentLength();
// 建立连接从请求中获取数据
URLConnection con = url.openConnection();
BufferedInputStream bin = new BufferedInputStream(httpURLConnection.getInputStream());
// 指定文件名称
String fileFullName = urlPath.subString(urlPath.lastIndexOf('/')+1).subString(0,15);
// 指定存放位置
path = downloadDir + File.separatorChar + fileFullName;
// 处理指定存放位置下的文件
file = new File(path);
// 校验文件夹目录是否存在,不存在就创建一个目录
if (!file.getParentFile().exists()) {
file.getParentFile().mkdirs();
}
// 创建输出流
OutputStream out = new FileOutputStream(file);
// 大小
int size = 0;
// 长度
int len = 0;
// 字节数组
byte[] buf = new byte[1024*2];
while ((size = bin.read(buf)) != -1) {
len += size;
out.write(buf,0,size);
logger.info("----[下载了:]" + len * 100 / fileLength + "%\n ]----");
}
// 关闭资源
bin.close();
out.close();
} catch (MalformedURLException e){
logger.error("异常:" + e.getMessage());
} catch (IOException e){
logger.error("异常:" + e.getMessage());
} finally {
}
}
解压方法借鉴专业工具 Hutool