mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2025-09-20 11:47:57 +08:00
decompress after decrypt if necessary
skip any decompress error
This commit is contained in:
@@ -18,10 +18,14 @@ public class Gzip {
|
|||||||
return compressed;
|
return compressed;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static byte[] decompress(byte[] compressed) throws IOException {
|
public static byte[] decompress(byte[] compressed) {
|
||||||
|
try {
|
||||||
ByteArrayInputStream bis = new ByteArrayInputStream(compressed);
|
ByteArrayInputStream bis = new ByteArrayInputStream(compressed);
|
||||||
GZIPInputStream gis = new GZIPInputStream(bis);
|
GZIPInputStream gis = new GZIPInputStream(bis);
|
||||||
return readAll(gis);
|
return readAll(gis);
|
||||||
|
} catch (Exception e) {
|
||||||
|
return compressed;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static byte[] readAll(InputStream input) throws IOException {
|
private static byte[] readAll(InputStream input) throws IOException {
|
||||||
|
@@ -119,6 +119,10 @@ public class SeaweedRead {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (chunkView.isCompressed) {
|
||||||
|
data = Gzip.decompress(data);
|
||||||
|
}
|
||||||
|
|
||||||
LOG.debug("doFetchFullChunkData fid:{} chunkData.length:{}", chunkView.fileId, data.length);
|
LOG.debug("doFetchFullChunkData fid:{} chunkData.length:{}", chunkView.fileId, data.length);
|
||||||
|
|
||||||
return data;
|
return data;
|
||||||
|
Reference in New Issue
Block a user