有没有办法将Java字符串转换为字节[](不是盒装的字节[])?
在尝试的过程中:
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());
得到不同的输出。无法显示第一个输出,因为它是一个gzip字符串。
<A Gzip String>
******
[B@38ee9f13
第二个是地址。我做错什么了吗?我需要一个字节[]形式的结果,以便将其提供给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[] 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表示字节[],38ee9f13是内存地址,用@分隔。
为了显示,你可以使用:
Arrays.toString(bytes);
但这只会显示为逗号分隔的整数序列,这可能是你想要的,也可能不是。
要从字节[]返回一个可读的字符串,使用:
String string = new String(byte[] bytes, Charset charset);
偏爱Charset版本的原因是,Java中的所有String对象都以UTF-16的形式存储在内部。当转换为字节[]时,您将得到String的给定字形的不同字节分解,这取决于所选择的字符集。
decompressGZIP()方法需要的对象是一个字节[]。
所以你刚才问的这个问题的基本技术答案是:
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表示字节[],38ee9f13是内存地址,用@分隔。
为了显示,你可以使用:
Arrays.toString(bytes);
但这只会显示为逗号分隔的整数序列,这可能是你想要的,也可能不是。
要从字节[]返回一个可读的字符串,使用:
String string = new String(byte[] bytes, Charset charset);
偏爱Charset版本的原因是,Java中的所有String对象都以UTF-16的形式存储在内部。当转换为字节[]时,您将得到String的给定字形的不同字节分解,这取决于所选择的字符集。