小编典典

如何将Java字符串转换为字节[]?

all

有什么方法可以将 Java 转换Stringbyte[]不是 盒装的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());
}

阅读 89

收藏
2022-03-08

共1个答案

小编典典

您的方法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);

但这只会显示为逗号分隔的整数序列,这可能是也可能不是您想要的。

要从 a 中获取可读String返回byte[],请使用:

String string = new String(byte[] bytes, Charset charset);

喜欢该Charset版本的原因是 Java 中的所有String对象都在内部存储为 UTF-16。转换为 a 时,byte[]您将获得 that
的给定字形的不同字节细分String,具体取决于所选的字符集。

2022-03-08