使用apache commons编解码器的Base64解码在非常大的二进制文件上失败

时间:2011-07-27 22:18:55

标签: java base64 fileinputstream apache-commons-codec

我正在开发加密工具,对于我们的加密文件格式,我使用Base64来编码数据。我正在使用apache commons编解码器使用围绕FileInputStream的Base64InputStream来解码文件。在我在大型音乐文件上测试之前,这就像一个魅力。出于一些神秘的原因,当我这样做时,字节6028之后的每个字节变为0.将其读入字节[]的代码如下:

FileInputStream filein = new FileInputStream(filename);
Base64InputStream in = new Base64InputStream(filein,false,76,'\n');
byte[] contents = new byte[known_and_tested_correct_filelength];
in.read(contents);

现在,无论出于何种原因,在字节6028之后,contents中的所有内容都为0.但是,contents.length大约为300,000字节。你可以猜到,这对我的应用程序来说确实很奇怪。有没有人知道发生了什么?

1 个答案:

答案 0 :(得分:7)

in.read()的语义不是读取所提供缓冲区中的所有字节,而是读取“准备就绪”的数量,并告诉您有多少字节。

然后,您必须重复调用in.read()以获取下一个块和下一个块等,直到获得-1。

您当前的代码只获取第一个块,然后丢弃块的大小。