Gibt es eine Möglichkeit, Java String
in ein Byte[]
(nicht die boxed Byte[]
) zu konvertieren?
Ich habe dies versucht:
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());
und ich erhalte getrennte Ausgaben. Die erste Ausgabe kann nicht angezeigt werden, da es sich um einen gzip-String handelt.
<A Gzip String>
******
[B@38ee9f13
Die zweite ist eine Adresse. Mache ich irgendetwas falsch? Ich brauche das Ergebnis in einem Byte[]
, um es an den gzip-Dekompressor zu übergeben, der wie folgt aussieht.
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());
}
Das Objekt, das Ihre Methode decompressGZIP()
benötigt, ist ein Byte[]
.
Die grundsätzliche, technische Antwort auf die Frage, die Sie gestellt haben, lautet also:
byte[] b = string.getBytes();
byte[] b = string.getBytes(Charset.forName("UTF-8"));
byte[] b = string.getBytes(StandardCharsets.UTF_8); // Java 7+ only
Das Problem, mit dem Sie zu ringen scheinen, ist jedoch, dass dies nicht sehr gut angezeigt wird. Der Aufruf von "toString()" liefert nur den Standardwert "Object.toString()", also den Klassennamen + Speicheradresse. In Ihrem Ergebnis [B@38ee9f13
steht das [B
für Byte[]
und 38ee9f13
ist die Speicheradresse, getrennt durch ein @
.
Für Anzeigezwecke können Sie verwenden:
Arrays.toString(bytes);
Dies wird jedoch nur als eine Folge von durch Kommas getrennten ganzen Zahlen angezeigt, was nicht unbedingt das ist, was Sie wollen.
Um einen lesbaren String
von einem Byte[]
zurückzubekommen, verwenden Sie:
String string = new String(byte[] bytes, Charset charset);
Der Grund, warum die Charset
-Version bevorzugt wird, ist, dass alle String
-Objekte in Java intern als UTF-16 gespeichert werden. Bei der Konvertierung in ein Byte[]
erhält man je nach gewähltem Zeichensatz eine andere Aufteilung der Bytes für die gegebenen Glyphen des String
.
String example = "Convert Java String";
byte[] bytes = example.getBytes();
Einfach:
String abc="abcdefghight";
byte[] b = abc.getBytes();
Versuchen Sie, String.getBytes() zu verwenden. Sie gibt ein Byte[] zurück, das Zeichenkettendaten darstellt. Beispiel:
String data = "sample data";
byte[] byteData = data.getBytes();
Sie können String.getBytes()
verwenden, das das Array Byte[]
zurückgibt.
Sie sollten vielleicht versuchen, neue Zeichenfolge zurückzugeben(byteout.toByteArray(Charset.forName("UTF-8")))
Es ist nicht notwendig, java als String-Parameter zu ändern. Sie müssen den c-Code ändern, um einen String ohne Zeiger und in seinem Code zu erhalten:
Bool DmgrGetVersion (String szVersion);
Char NewszVersion [200];
Strcpy (NewszVersion, szVersion.t_str ());
.t_str () applies to builder c ++ 2010
Ich weiß, ich bin etwas spät dran, aber das funktioniert ziemlich gut (unser Professor hat es uns gegeben).
public static byte[] asBytes (String s) {
String tmp;
byte[] b = new byte[s.length() / 2];
int i;
for (i = 0; i < s.length() / 2; i++) {
tmp = s.substring(i * 2, i * 2 + 2);
b[i] = (byte)(Integer.parseInt(tmp, 16) & 0xff);
}
return b; //return bytes
}