在正常的开发工作中,很多时候需要对接其他公司的数据,有可能是一个文档、PDF、Excel,然后自己数据库又需要备份的时候,这个时候就需要先从别人家那边下载下来,然后保存到自己的服务上,话不多上,上代码:
/**
* 这里我直接在本地写了个测试方法
*/
@Test
public void testDownloadFile() throws IOException {
log.info("======测试下载网络文件,用于测试下载体检报告的方法======");
int bytesum = 0;
int byteread = 0;
URL url = new URL("这里写自己需要下载文件的文件源URL");
URLConnection conn = url.openConnection();
// 下载网络文件
InputStream inStream = conn.getInputStream();
// 需要保存的服务器地址,也就是需要把文件写出到什么地方,我这边是写出本地D盘
FileOutputStream fs = new FileOutputStream("d:/abc.pdf");
// 这里我用的是BufferedOutputStream,用FilterOutputStream也是可以实现的,但是效率有区别
BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(fs);
try {
// 这边定义byte[1024]大小完全够用
byte[] buffer = new byte[1024];
// inStream.read(buffer)将网络上的文件读入到内存中
while ((byteread = inStream.read(buffer)) != -1) {
bytesum += byteread;
System.out.println(bytesum);
// bufferedOutputStream.write是将内存中的字节写出到指定地方
bufferedOutputStream.write(buffer, 0, byteread);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
// 最后在finally中将流关闭掉,不然很占内存,浪费资源
inStream.close();
fs.close();
}
}
这个时候就能在D盘中看到这个文件了,这里显示557kb,说明是有内容下载成功的!!
另外,感兴趣的小伙伴可以去网上找找资料,看下BufferedOutputStream和FilterOutputStream的区别所在!!
最后,还需要啰嗦一句,写代码需要细心,在使用完流下载之后,不管下载文件有没有成功,都要在finally中将流关闭释放掉,不让很浪费资源。