我一直在尝试将数组缓冲区转换为人类可读的字符串,但当我尝试解码数组缓冲区时,它返回的是外部字符。
arrayBuffer = `[18, 32, 121, 49, 72, 220, 122, 210, 56, 86, 171, 17, 36, 81, 52, 151, 102, 70, 216, 254, 207, 175, 161, 253, 216, 30, 99, 35, 30, 121, 226, 96, 86, 94]`
var readableString = new TextDecoder('utf8').decode(arrayBuffer)我尝试使用text-encoding包对数组进行解码,但它返回y1H�z�8V�$Q4�fF��ϯ���c#y�`V^。为什么它不能被解码成人类可读的字符串?
发布于 2018-06-13 08:41:47
TextDecoder可能正在查看数字的原始二进制数据,然后将其转换为UTF-8字符串。C/C++具有此行为。如果想要将其转换为人类可读的字符串,可以使用Array.join或类似的方法将其转换为字符串。示例代码:
arrayBuffer = [18, 32, 121, 49, 72, 220, 122, 210, 56, 86, 171, 17, 36, 81, 52, 151, 102, 70, 216, 254, 207, 175, 161, 253, 216, 30, 99, 35, 30, 121, 226, 96, 86, 94];
var readableString = "[" + arrayBuffer.join(", ") + "]";
console.log(readableString)
https://stackoverflow.com/questions/50827630
复制相似问题