Existe alguma maneira de converter Java String
para um byte[]
( não o in a box Byte[]
)?
Ao tentar isso:
System.out.println(response.split("\r\n\r\n")[1]);
System.out.println("******");
System.out.println(response.split("\r\n\r\n")[1].getBytes().toString());
e estou recebendo saídas separadas. Não foi possível exibir a primeira saída, pois é uma sequência de gzip.
<A Gzip String>
******
[B@38ee9f13
O segundo é um endereço. Há algo que estou fazendo de errado? Eu preciso do resultado em um byte[]
para alimentá-lo ao descompactador gzip, que é o seguinte.
String decompressGZIP(byte[] gzip) throws IOException {
java.util.zip.Inflater inf = new java.util.zip.Inflater();
java.io.ByteArrayInputStream bytein = new java.io.ByteArrayInputStream(gzip);
java.util.zip.GZIPInputStream gzin = new java.util.zip.GZIPInputStream(bytein);
java.io.ByteArrayOutputStream byteout = new java.io.ByteArrayOutputStream();
int res = 0;
byte buf[] = new byte[1024];
while (res >= 0) {
res = gzin.read(buf, 0, buf.length);
if (res > 0) {
byteout.write(buf, 0, res);
}
}
byte uncompressed[] = byteout.toByteArray();
return (uncompressed.toString());
}
String.getBytes()
realmente retorna uma matriz de bytes, mas sua crença de que atoString()
matriz de bytes retornará um resultado útil está incorreta.Respostas:
O objeto que seu método
decompressGZIP()
precisa é umbyte[]
.Portanto, a resposta técnica básica à pergunta que você fez é:
No entanto, o problema com o qual você parece estar lutando é que isso não aparece muito bem. A chamada
toString()
apenas fornecerá o padrão,Object.toString()
que é o nome da classe + o endereço da memória. No seu resultado[B@38ee9f13
, os[B
meiosbyte[]
e38ee9f13
o endereço da memória, separados por um@
.Para fins de exibição, você pode usar:
Mas isso será exibido apenas como uma sequência de números inteiros separados por vírgula, que pode ou não ser o que você deseja.
Para obter um
String
retorno legível de abyte[]
, use:A razão pela qual a
Charset
versão é favorecida é que todos osString
objetos em Java são armazenados internamente como UTF-16. Ao converter para um,byte[]
você obterá uma divisão diferente de bytes para os glifos fornecidosString
, dependendo do conjunto de caracteres escolhido.fonte
string.getBytes(StandardCharsets.UTF_8)
também pode ser usado e é o mesmo questring.getBytes(Charset.forName("UTF-8"))
StandardCharsets
é novo no Java 7Charset.forName("UTF-8")
faz ou por que é importante.fonte
Tente usar String.getBytes (). Retorna um byte [] que representa os dados da string. Exemplo:
fonte
Simplesmente:
fonte
abc
contiver caracteres não US-ASCII, como"greater than 2³² − 1"
ou apenas dados binários (como " A 2")?�
essa sequência tem apenas 5 caracteres. No entanto, quando eu uso,getBytes()
tenho 7 caracteres.Você pode usar o
String.getBytes()
que retorna abyte[]
matriz.fonte
Você pode querer tentar
return new String(byteout.toByteArray(Charset.forName("UTF-8")))
fonte
Não é necessário alterar o java como um parâmetro String. Você precisa alterar o código c para receber uma String sem um ponteiro e em seu código:
fonte
Eu sei que estou um pouco atrasado para a festa, mas isso funciona muito bem (nosso professor nos deu)
fonte