Czy jest jakiś sposób przekonwertować Javę String
na byte[]
( nie w pudełku Byte[]
)?
Próbując tego:
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());
i otrzymuję osobne wyniki. Nie można wyświetlić pierwszego wyjścia, ponieważ jest to ciąg gzip.
<A Gzip String>
******
[B@38ee9f13
Drugi to adres. Czy coś robię źle? Potrzebuję wyniku w, byte[]
aby podać go do dekompresora gzip, który jest następujący.
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()
rzeczywiście zwraca tablicę bajtów, ale twoje przekonanie, żetoString()
tablica bajtów zwróci użyteczny wynik, jest błędne.Odpowiedzi:
Obiekt, którego
decompressGZIP()
potrzebuje Twoja metoda, tobyte[]
.Tak więc podstawowa, techniczna odpowiedź na zadane pytanie brzmi:
Jednak problemem, z którym wydajesz się walczyć, jest to, że nie wyświetla się to zbyt dobrze. Wywołanie
toString()
da ci tylko domyślnąObject.toString()
nazwę, którą jest nazwa klasy + adres pamięci. W swoim rezultacie[B@38ee9f13
, te[B
środkibyte[]
i38ee9f13
to adres pamięci, oddzielone@
.Do celów wyświetlania możesz użyć:
Ale wyświetli się to jako sekwencja liczb całkowitych oddzielonych przecinkami, które mogą, ale nie muszą, być tym, czego chcesz.
Aby uzyskać czytelny
String
wróciłem zbyte[]
, należy:Powodem
Charset
wersja jest faworyzowany, jest to, że wszystkieString
obiekty w Javie są przechowywane wewnętrznie jako UTF-16. Konwertując na abyte[]
otrzymasz inny podział bajtów dla danych glifówString
, w zależności od wybranego zestawu znaków.źródło
string.getBytes(StandardCharsets.UTF_8)
można również użyć i jest to to samo, costring.getBytes(Charset.forName("UTF-8"))
StandardCharsets
jest nowy w Javie 7Charset.forName("UTF-8")
robi różnicę ani dlaczego jest taka ważna.źródło
Spróbuj użyć String.getBytes (). Zwraca bajt [] reprezentujący dane ciągu. Przykład:
źródło
Po prostu:
źródło
abc
zawiera znaki spoza US-ASCII, takie jak"greater than 2³² − 1"
lub tylko dane binarne (takie jak „ A b2”)?�
ten ciąg ma tylko 5 znaków. Jednak kiedy używam,getBytes()
mam 7 znaków.Możesz użyć,
String.getBytes()
który zwracabyte[]
tablicę.źródło
Możesz spróbować
return new String(byteout.toByteArray(Charset.forName("UTF-8")))
źródło
Nie trzeba zmieniać Java jako parametru String. Musisz zmienić kod c, aby otrzymać ciąg bez wskaźnika i jego kod:
źródło
Wiem, że jestem trochę spóźniony na imprezę, ale działa całkiem nieźle (nasz profesor nam to dał)
źródło