【发布时间】:2014-06-25 09:58:37
【问题描述】:
我希望有人能阐明我在使用下面的代码时遇到的问题。
private static String encode(String data) throws IOException {
try (
ByteArrayOutputStream out = new ByteArrayOutputStream();
InputStream is = new ByteArrayInputStream(data.getBytes());
BufferedReader br = new BufferedReader(new InputStreamReader(is));
OutputStreamWriter writer = new OutputStreamWriter(new GZIPOutputStream(out));
) {
char[] charBuffer = new char[data.length()];
while (br.read(charBuffer) != -1) {
writer.write(charBuffer);
}
// writer.close();
return new String(Base64.encodeBase64(out.toByteArray()));
}
}
我的测试值是
This is some text that I can test some base64 encoding with.
I am getting a strange problem with the encoded value
当 writer.close 被注释掉时,我的输出是
H4sIAAAAAAAAAA==
当它没有被评论时,我的输出是
H4sIAAAAAAAAACWMzQ2DMBSD70jdwRP0VLED9y7wACuJRJKKZ37GJxTJF/uz/Y3J0eQ1E+IpKJowYLLSvOshozn7D1imOqcScCTF96sbYBmB0p0ZXKuVQPzWOi7M/1b747PjjN2WjRd08DfZcwAAAA==
第二个输出是正确的值,可以解码回原始值。 据我了解,流程如下:
- 尝试代码被执行
- 返回值被评估和存储
- 资源全部关闭
- 返回值。
那么为什么需要关闭编写器才能使输出正确?
【问题讨论】:
-
尝试添加 writer.flush() 而不是关闭。可能是在您读取之前,该流尚未完全写入。
-
@AndrewVitkus 对不起,我应该提到我也尝试过冲洗。不幸的是,刷新而不是关闭仍然会导致编码不正确。
-
我会用flush()重试。另外,正确地说,您的代码应该只写入
br.read()实际读取的字符数,而不是 wole char 数组。 -
由于关闭 writer 也应该关闭,您可以在 try 之外声明并在其中分配。然后,您也可以将 return 移到 try 之外。当然,这需要对 out 和其他此类不愉快的情况进行空检查,因此仅包括 close 可能是最优雅的解决方案。
-
对不起,我之前的评论有误。必须关闭 GZIP 流才能完成压缩并写入结果。因此,刷新作者,并至少关闭 gzip 流。无论如何关闭作者都不会受到伤害。
标签: java outputstream gzipoutputstream