【问题标题】:Too large files when downloading Piktogramms下载象形图时文件太大
【发布时间】:2017-02-21 18:29:46
【问题描述】:

我正在尝试下载托管方提供的一些图片。这是我使用的方法:

public static void downloadImage(String imageLink, File f) throws IOException
{
    URL url = new URL(imageLink);
    byte[] buffer = new byte[1024];
    BufferedInputStream in = new BufferedInputStream(url.openStream(), buffer.length);
    BufferedOutputStream out = new BufferedOutputStream(new FileOutputStream(f), buffer.length);

    while (in.read(buffer) > 0)
        out.write(buffer);
    out.flush();
    out.close();
    in.close();
}

但是,文件太大了。在我看来,80x60 jpg 的 5MB 太大了。

这可能是什么原因?

【问题讨论】:

  • 帮自己一个忙,并为此使用库。我最喜欢的流复制是 Apache Commons IOUtils (commons.apache.org/proper/commons-io/javadocs/api-release/org/…)
  • 不客气;感谢您的快速接受。
  • 附注;我同意托马斯的观点:除非这是一些“教育练习”——你最好使用一些图书馆来做到这一点。
  • @GhostCat 现在我还在接受教育,所以我想在不使用库的情况下尽可能多地了解 java 的各个方面,但我也会牢记这个建议。

标签: java url filestream


【解决方案1】:

你在这里做错了:read() 返回真正读取的字节数;因此,您必须将缓冲区数组中的确切数字写入输出流。

您的代码正在破坏您的输出;并简单地写出一个缓冲区数组......主要由 0 组成!

改为:

int bytesRead;
while ( ( bytesRead = in.read(buffer)) > 0) {
   byte outBuffer[] = new byte[bytesRead];
   ... then use arraycopy to move bytesRead bytes
   out.write(outBuffer);
}

(这是一种激励你前进的灵感,更像是伪代码而不是真实代码)

【讨论】:

  • 谢谢。我一定会记住这个事实
猜你喜欢
  • 1970-01-01
  • 2015-11-15
  • 2019-06-10
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-01-12
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多