Есть ли способ преобразовать Java String
в byte []
(not в штучной упаковке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 []
вы получите другую разбивку байтов для заданных глифов этого String
, в зависимости от выбранной кодировки.
String example = "Convert Java String";
byte[] bytes = example.getBytes();
Просто:
String abc="abcdefghight";
byte[] b = abc.getBytes();
Попробуйте использовать String.getBytes (). Возвращает байт [], представляющий строковые данные. Пример:
String data = "sample data";
byte[] byteData = data.getBytes();
Вы можете использовать String.getBytes ()
, который возвращает массив byte []
.
Вы можете попробовать return new String (byteout.toByteArray (Charset.forName ("UTF-8"))
Нет необходимости изменять Java как параметр String. Вы должны изменить код c, чтобы получить строку без указателя и в ее коде:
Bool DmgrGetVersion (String szVersion);
Char NewszVersion [200];
Strcpy (NewszVersion, szVersion.t_str ());
.t_str () applies to builder c ++ 2010
Я знаю, что немного опаздываю на вечеринку, но это работает довольно аккуратно (наш профессор дал это нам)
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
}