我正在将Java中的GZIP字节数组转换为String形式。这是一个很大的文件,想法是将其转换为JSON。
但是我得到的异常很奇怪,并且没有多大意义。
代码段:
public static String convert(byte[] bytes) throws IOException {
final byte[] BUFFER = new byte[16234];
GZIPInputStream gzipInputStream = new GZIPInputStream(new ByteArrayInputStream(bytes));
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
int len;
while ((len = gzipInputStream.read(BUFFER)) >= 0) {
byteArrayOutputStream.write(BUFFER, 0, len);
if(byteArrayOutputStream.size ()>60812918){
System.out.println ( "stopping here" );
}
}
byteArrayOutputStream.flush();
byteArrayOutputStream.close();
gzipInputStream.close();
final byte[] dataPart = byteArrayOutputStream.toByteArray();
String data = new String(dataPart, StandardCharsets.UTF_8);
return data;
}
异常跟踪:
java.io.EOFException: Unexpected end of ZLIB input stream
at java.util.zip.InflaterInputStream.fill(InflaterInputStream.java:240)
at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:158)
at java.util.zip.GZIPInputStream.read(GZIPInputStream.java:117)
at java.io.FilterInputStream.read(FilterInputStream.java:107)
at com.here.rcs.discoverkernels.testS3FileReader.convert(testS3FileReader.java:84)
at com.here.rcs.discoverkernels.testS3FileReader.viewJson(testS3FileReader.java:45)
at com.here.rcs.discoverkernels.testS3FileReader.main(testS3FileReader.java:21)
从编码的角度来看,我认为这段代码没有什么问题。
任何建议如何进行此操作。
添加到字节转换部分;
public static byte[] compress(final String data) throws IOException {
final byte[] dataPart = data.getBytes( StandardCharsets.UTF_8 );
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
GZIPOutputStream gzipOutputStream = new GZIPOutputStream(byteArrayOutputStream);
gzipOutputStream.write(dataPart);
gzipOutputStream.flush();
gzipOutputStream.close();
byte[] bytes = byteArrayOutputStream.toByteArray();
return bytes;
}
答案 0 :(得分:0)
我用一个小的.gz文件尝试了您的程序,它可以按预期工作。我想是
bytes
数组中。你怎么样我关注了这篇文章:https://netjs.blogspot.com/2015/11/how-to-convert-file-to-byte-array-java.html