Есть ли способ конвертировать Java String
в 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());
}
String.getBytes()
он действительно возвращает байтовый массив, но ваша вера в то, чтоtoString()
байтовый массив вернет полезный результат, неверна.Ответы:
Объект, в котором
decompressGZIP()
нуждается ваш метод, этоbyte[]
.Итак, основной технический ответ на заданный вами вопрос:
Однако проблема, с которой вы, похоже, боретесь, заключается в том, что это выглядит не очень хорошо. Вызов
toString()
по умолчанию просто даст вамObject.toString()
имя класса + адрес памяти. В вашем результате[B@38ee9f13
, то[B
значитbyte[]
и38ee9f13
является адрес памяти, отделенный друг от друга@
.Для отображения вы можете использовать:
Но это будет отображаться как последовательность целых чисел, разделенных запятыми, которые могут быть или не быть тем, что вы хотите.
Для того, чтобы получить читаемый
String
назад отbyte[]
, используйте:Причиной
Charset
предпочтения версии является то, что всеString
объекты в Java хранятся внутри как UTF-16. При преобразовании в abyte[]
вы получите различную разбивку байтов для заданных символовString
, в зависимости от выбранной кодировки.источник
string.getBytes(StandardCharsets.UTF_8)
также может быть использован, и это то же самое, чтоstring.getBytes(Charset.forName("UTF-8"))
StandardCharsets
это ново с Java 7Charset.forName("UTF-8")
делает разницу или почему это важно.источник
Попробуйте использовать String.getBytes (). Возвращает byte [], представляющий строковые данные. Пример:
источник
Просто:
источник
abc
не символы US-ASCII, например,"greater than 2³² − 1"
или просто двоичные данные (например, « A b2»)?�
эта строка имеет только 5 символов. Однако, когда я использую,getBytes()
я получил 7 символов.Вы можете использовать
String.getBytes()
который возвращаетbyte[]
массив.источник
Вы можете попробовать
return new String(byteout.toByteArray(Charset.forName("UTF-8")))
источник
Нет необходимости изменять Java в качестве параметра String. Вы должны изменить код c, чтобы получить строку без указателя и в своем коде:
источник
Я знаю, что немного опоздал на вечеринку, но это работает довольно аккуратно (наш профессор дал нам это)
источник