有什么方法可以将 Java 转换String为byte[]( 不是 盒装的Byte[])?
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());
我得到了单独的输出。无法显示第一个输出,因为它是 gzip 字符串。
<A Gzip String> ****** [B@38ee9f13
第二个是地址。有什么我做错了吗?我需要 a 中的结果将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[].
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表示byte[]和38ee9f13是内存地址,以 . 分隔@。
toString()
Object.toString()
[B@38ee9f13
[B
38ee9f13
@
出于显示目的,您可以使用:
Arrays.toString(bytes);
但这只会显示为逗号分隔的整数序列,这可能是也可能不是您想要的。
要从 a 中获取可读String返回byte[],请使用:
String string = new String(byte[] bytes, Charset charset);
喜欢该Charset版本的原因是 Java 中的所有String对象都在内部存储为 UTF-16。转换为 a 时,byte[]您将获得 that 的给定字形的不同字节细分String,具体取决于所选的字符集。
Charset