Tengo un problema en el código:GZIP y el byte de conversión
private static String compress(String str)
{
String str1 = null;
ByteArrayOutputStream bos = null;
try
{
bos = new ByteArrayOutputStream();
BufferedOutputStream dest = null;
byte b[] = str.getBytes();
GZIPOutputStream gz = new GZIPOutputStream(bos,b.length);
gz.write(b,0,b.length);
bos.close();
gz.close();
}
catch(Exception e) {
System.out.println(e);
e.printStackTrace();
}
byte b1[] = bos.toByteArray();
return new String(b1);
}
private static String deCompress(String str)
{
String s1 = null;
try
{
byte b[] = str.getBytes();
InputStream bais = new ByteArrayInputStream(b);
GZIPInputStream gs = new GZIPInputStream(bais);
ByteArrayOutputStream baos = new ByteArrayOutputStream();
int numBytesRead = 0;
byte [] tempBytes = new byte[6000];
try
{
while ((numBytesRead = gs.read(tempBytes, 0, tempBytes.length)) != -1)
{
baos.write(tempBytes, 0, numBytesRead);
}
s1 = new String(baos.toByteArray());
s1= baos.toString();
}
catch(ZipException e)
{
e.printStackTrace();
}
}
catch(Exception e) {
e.printStackTrace();
}
return s1;
}
public String test() throws Exception
{
String str = "teststring";
String cmpr = compress(str);
String dcmpr = deCompress(cmpr);
}
Este java.io.IOException código de tiro: formato desconocido (número mágico ef1f)
GZIPInputStream gs = new GZIPInputStream(bais);
Resulta que al convertir el byte new String (b1)
y byte b [] = str.getBytes()
los bytes están "dañados". En la salida de la línea ya tenemos más bytes. Si evita la conversión a una cadena y trabaja en línea con bytes, todo funciona. Lo siento por mi ingles.
public String unZip(String zipped) throws DataFormatException, IOException {
byte[] bytes = zipped.getBytes("WINDOWS-1251");
Inflater decompressed = new Inflater();
decompressed.setInput(bytes);
byte[] result = new byte[100];
ByteArrayOutputStream buffer = new ByteArrayOutputStream();
while (decompressed.inflate(result) != 0)
buffer.write(result);
decompressed.end();
return new String(buffer.toByteArray(), charset);
}
estoy utilización de esta función para descomprimir responce servidor. Gracias por la ayuda.
Uso default_charset() == "UTF-8". Esto es solo prueba. –
@AlexandrErofeev: No estará claro cuando alguien está * leyendo * El código que codifica para usar. IMO es mucho mejor decirlo explícitamente. (Y si es solo como una prueba, elimine por completo todo el manejo de excepciones, y simplemente deje que todos los métodos arrojen 'IOException' - simplificará el código.) –