Υπάρχει κάποιος τρόπος να μετατρέψετε το String
της Java σε byte[]
(όχι το πλαίσιο Byte[]
);
Προσπαθώντας αυτό:
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());
και λαμβάνω ξεχωριστές εξόδους. Δεν είναι δυνατή η εμφάνιση της 1ης εξόδου, καθώς πρόκειται για συμβολοσειρά gzip.
<A Gzip String>
******
[B@38ee9f13
Η δεύτερη είναι μια διεύθυνση. Υπάρχει κάτι που κάνω λάθος; Χρειάζομαι το αποτέλεσμα σε ένα byte[]
για να το τροφοδοτήσω στον gzip αποσυμπιεστή, ο οποίος έχει ως εξής.
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());
}
Το αντικείμενο που χρειάζεται η μέθοδος decompressGZIP()
είναι ένα byte[]
.
Έτσι, η βασική, τεχνική απάντηση στο ερώτημα που θέσατε είναι:
byte[] b = string.getBytes();
byte[] b = string.getBytes(Charset.forName("UTF-8"));
byte[] b = string.getBytes(StandardCharsets.UTF_8); // Java 7+ only
Ωστόσο, το πρόβλημα με το οποίο φαίνεται να παλεύετε είναι ότι αυτό δεν εμφανίζεται πολύ καλά. Η κλήση της toString()
θα σας δώσει απλά την προεπιλεγμένη Object.toString()
που είναι το όνομα της κλάσης + διεύθυνση μνήμης. Στο αποτέλεσμά σας [B@38ee9f13
, το [B
σημαίνει byte[]
και το 38ee9f13
είναι η διεύθυνση μνήμης, χωρισμένο με ένα @
.
Για σκοπούς απεικόνισης μπορείτε να χρησιμοποιήσετε:
Arrays.toString(bytes);
Αλλά αυτό θα εμφανιστεί απλώς ως μια ακολουθία ακεραίων αριθμών διαχωρισμένων με κόμμα, που μπορεί να είναι ή να μην είναι αυτό που θέλετε.
Για να λάβετε ένα αναγνώσιμο String
από ένα byte[]
, χρησιμοποιήστε:
String string = new String(byte[] bytes, Charset charset);
Ο λόγος που προτιμάται η έκδοση Charset
είναι ότι όλα τα αντικείμενα String
στη Java αποθηκεύονται εσωτερικά ως UTF-16. Κατά τη μετατροπή σε ένα byte[]
θα λάβετε μια διαφορετική κατανομή bytes για τα συγκεκριμένα glyphs αυτού του String
, ανάλογα με το επιλεγμένο charset.
String example = "Convert Java String";
byte[] bytes = example.getBytes();
Μπορείτε να χρησιμοποιήσετε την String.getBytes()
η οποία επιστρέφει τον πίνακα byte[]
.