将字节数组放到JSON中,反之亦然

Ami*_* Sh 48 java json bytearray

是否可以将byte[](字节数组)放入JSON

如果是这样,我怎么能在java中这样做?然后读取该JSON并再次将该字段转换为byte[]

Sam*_*lly 60

这是base64编码字节数组的一个很好的例子.当您在混合中输入unicode字符以发送PDF文档之类的内容时,会变得更加复杂.在对字节数组进行编码之后,编码的字符串可以用作JSON属性值.

Apache commons提供了很好的实用程序:

 byte[] bytes = getByteArr();
 String base64String = Base64.encodeBase64String(bytes);
 byte[] backToBytes = Base64.decodeBase64(base64String);
Run Code Online (Sandbox Code Playgroud)

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Base64_encoding_and_decoding

Java服务器端示例:

public String getUnsecureContentBase64(String url)
        throws ClientProtocolException, IOException {

            //getUnsecureContent will generate some byte[]
    byte[] result = getUnsecureContent(url);

            // use apache org.apache.commons.codec.binary.Base64
            // if you're sending back as a http request result you may have to
            // org.apache.commons.httpclient.util.URIUtil.encodeQuery
    return Base64.encodeBase64String(result);
}
Run Code Online (Sandbox Code Playgroud)

JavaScript解码:

//decode URL encoding if encoded before returning result
var uriEncodedString = decodeURIComponent(response);

var byteArr = base64DecToArr(uriEncodedString);

//from mozilla
function b64ToUint6 (nChr) {

  return nChr > 64 && nChr < 91 ?
      nChr - 65
    : nChr > 96 && nChr < 123 ?
      nChr - 71
    : nChr > 47 && nChr < 58 ?
      nChr + 4
    : nChr === 43 ?
      62
    : nChr === 47 ?
      63
    :
      0;

}

function base64DecToArr (sBase64, nBlocksSize) {

  var
    sB64Enc = sBase64.replace(/[^A-Za-z0-9\+\/]/g, ""), nInLen = sB64Enc.length,
    nOutLen = nBlocksSize ? Math.ceil((nInLen * 3 + 1 >> 2) / nBlocksSize) * nBlocksSize : nInLen * 3 + 1 >> 2, taBytes = new Uint8Array(nOutLen);

  for (var nMod3, nMod4, nUint24 = 0, nOutIdx = 0, nInIdx = 0; nInIdx < nInLen; nInIdx++) {
    nMod4 = nInIdx & 3;
    nUint24 |= b64ToUint6(sB64Enc.charCodeAt(nInIdx)) << 18 - 6 * nMod4;
    if (nMod4 === 3 || nInLen - nInIdx === 1) {
      for (nMod3 = 0; nMod3 < 3 && nOutIdx < nOutLen; nMod3++, nOutIdx++) {
        taBytes[nOutIdx] = nUint24 >>> (16 >>> nMod3 & 24) & 255;
      }
      nUint24 = 0;

    }
  }

  return taBytes;
}
Run Code Online (Sandbox Code Playgroud)


Sot*_*lis 10

在json中发送二进制文件的典型方法是对其进行base64编码.

Java为Base64编码和解码提供了不同的方法byte[].其中之一是DatatypeConverter.

非常简单

byte[] originalBytes = new byte[] { 1, 2, 3, 4, 5};
String base64Encoded = DatatypeConverter.printBase64Binary(originalBytes);
byte[] base64Decoded = DatatypeConverter.parseBase64Binary(base64Encoded);
Run Code Online (Sandbox Code Playgroud)

您必须根据您使用的json解析器/生成器库进行此转换.


Art*_*2e5 6

与 @Qwertie 的建议一致,但在懒惰方面更进一步,您可以假装每个字节都是 ISO-8859-1 字符。对于外行来说,ISO-8859-1 是一种单字节编码,与 Unicode 的前 256 个代码点相匹配。

所以@Ash的答案实际上可以用字符集来兑换:

byte[] args2 = getByteArry();
String byteStr = new String(args2, Charset.forName("ISO-8859-1"));
Run Code Online (Sandbox Code Playgroud)

这种编码具有与 BAIS 相同的可读性,其优点是处理速度比 BAIS 或 base64 更快,因为需要的分支更少。看起来 JSON 解析器做得有点多,但这没关系,因为通过转义或 UTF-8 处理非 ASCII 无论如何都是 JSON 解析器工作的一部分。它可以更好地映射到某些格式,例如带有配置文件的 MessagePack。

然而,就空间而言,这通常是一种损失。对于 UTF-8,每个非 ASCII 字节将占用 2 个字节,而 BAIS对于每次 3 n + r这样的字节(r 是余数)使用 (2+4 n + r ?( r +1):0) 个字节。这对于 UTF-16 来说是一个胜利,但是谁用它来处理 JSON 呢?(Base64 始终以 4/3 的开销运行。对于 ASCII 丰富的内容来说这将是一个胜利。)

(这种编码技巧适用于任何语言——8859-1 得到了广泛的支持。它也称为 Latin-1。)

  • 严重低估的答案。 (3认同)