java+根据多个url批量下载⽂件
1.基本流程
当我们想要下载⽹站上的某个资源时,我们会获取⼀个url,它是服务器定位资源的⼀个描述,下载的过程有如下⼏步:(1)客户端发起⼀个url请求,获取连接对象。
(2)服务器解析url,并且将指定的资源返回⼀个输⼊流给客户。
(3)建⽴存储的⽬录以及保存的⽂件名。
(4)输出了写数据。
(5)关闭输⼊流和输出流。
2.实现代码的⽅法
/**
* 从⽹络Url中下载⽂件
* @param urlStr
* @param fileName
* @param savePath
* @throws IOException
*/
public static void downLoadFromUrl(String urlStr,String fileName,String savePath) throws IOException{
URL url = new URL(urlStr);
HttpURLConnection conn = (HttpURLConnection)url.openConnection();
//设置超时间为3秒
conn.setConnectTimeout(3*1000);
//防⽌屏蔽程序抓取⽽返回403错误
conn.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)");
//得到输⼊流
InputStream inputStream = InputStream();
//获取⾃⼰数组
byte[] getData = readInputStream(inputStream);
//⽂件保存位置
File saveDir = new File(savePath);
if(!ists()){
saveDir.mkdir();
}
File file = new File(saveDir+File.separator+fileName);
FileOutputStream fos = new FileOutputStream(file);
fos.write(getData);
if(fos!=null){
fos.close();
}
if(inputStream!=null){
inputStream.close();
}
System.out.println("info:"+url+" download success");
}
/**
* 从输⼊流中获取字节数组
connect下载* @param inputStream
* @return
* @throws IOException
*/
public static byte[] readInputStream(InputStream inputStream) throws IOException {
byte[] buffer = new byte[1024];
int len = 0;
ByteArrayOutputStream bos = new ByteArrayOutputStream();
while((len = ad(buffer)) != -1) {
bos.write(buffer, 0, len);
}
bos.close();
ByteArray();
}
public static void main(String[] args) {
try{
downLoadFromUrl("101.95.48.97:8005/res/upload/interface/apptutorials/manualstypeico/6f83ce8f-0da5-49b3-bac8-fd5fc67d2725.png",
"百度.jpg","d:/resource/images/diaodiao/country/");
}catch (Exception e) {
// TODO: handle exception
}
}
效果展现:
<img src="/869c614f.jpg" data-ke-src="/869c614f.jpg" ,="" tahoma,="" verdana,="" helvetica;="" font-size:="" 12px;="" white-space:="" normal;"="" alt="" sans serif"">
详细配置可参考我写的这篇⽂章:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论