在正常的开发工作中,很多时候需要对接其他公司的数据,有可能是一个文档、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中将流关闭释放掉,不让很浪费资源。