Existe-t-il un moyen de convertir un String
de Java en un byte[]
(non le Byte[]
encadré) ?
En essayant ceci :
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());
et j'obtiens des sorties séparées. Impossible d'afficher la première sortie car il s'agit d'une chaîne gzip.
<A Gzip String>
******
[B@38ee9f13
La seconde est une adresse. Y a-t-il quelque chose que je fais mal ? J'ai besoin du résultat dans un byte[]
pour l'envoyer au décompresseur gzip, qui est le suivant.
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());
}
L'objet dont votre méthode decompressGZIP()
a besoin est un byte[]
.
La réponse technique de base à la question que vous avez posée est donc la suivante :
byte[] b = string.getBytes();
byte[] b = string.getBytes(Charset.forName("UTF-8"));
byte[] b = string.getBytes(StandardCharsets.UTF_8); // Java 7+ only
Cependant, le problème auquel vous semblez être confronté est que cela ne s'affiche pas très bien. L'appel à toString()
vous donnera juste la valeur par défaut Object.toString()
qui est le nom de la classe + l'adresse mémoire. Dans votre résultat [B@38ee9f13
, le [B
] signifie byte[]
et 38ee9f13
est l'adresse mémoire, séparée par un @
.
Pour l'affichage, vous pouvez utiliser :
Arrays.toString(bytes);
Mais cela ne fera qu'afficher une séquence d'entiers séparés par des virgules, ce qui n'est pas forcément ce que vous voulez.
Pour obtenir un String
lisible à partir d'un byte[]
, utilisez :
String string = new String(byte[] bytes, Charset charset);
La raison pour laquelle la version Charset
est privilégiée, est que tous les objets String
de Java sont stockés en interne en UTF-16. Lors de la conversion en byte[]
, vous obtiendrez une répartition différente des octets pour les glyphes donnés de cette String
, en fonction du jeu de caractères choisi.