Lil*_*ung 3 java base64 fileinputstream apache-commons-codec
我正在开发加密工具,对于我们的加密文件格式,我使用Base64来编码数据.我正在使用apache commons编解码器使用围绕FileInputStream的Base64InputStream来解码文件.在我在大型音乐文件上测试之前,这就像一个魅力.出于一些神秘的原因,当我这样做时,字节6028之后的每个字节变为0.将其读入byte []的代码如下:
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);
Run Code Online (Sandbox Code Playgroud)
现在,无论出于何种原因,在字节6028之后,所有内容contents都是0.但是,contents.length大约是300,000字节.你可以猜到,这对我的应用程序来说确实很奇怪.有没有人知道发生了什么?
语义in.read()不是读取所提供的缓冲区中的所有字节,而是读取"准备好"的数量,并让你知道它有多少.
然后,您必须重复调用以in.read()获取下一个块和下一个块等,直到获得-1.
您当前的代码只获得第一个块,并且您丢弃了块的大小.
| 归档时间: |
|
| 查看次数: |
848 次 |
| 最近记录: |