Java下载文件笔记

本文介绍了如何使用Java代码实现从网络下载文件,并保存到本地服务器的过程,重点讲解了BufferedOutputStream的使用及其与FilterOutputStream的区别。

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

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值