这是我如何使用 pako 压缩二进制字符串(255 以上的字符代码):
var charData = xhr.responseText.split('').map(function(x){return x.charCodeAt(0);});
var binData = new Uint8Array(charData);
var data = pako.deflate(binData, {level:"9"});
这是我将数据解压回来的方法:
var data2 = pako.inflate(xhr.responseText);
现在,我如何从这个对象获取 JavaScript 中的原始字符串? 我尝试过这样的方法:
A.
pako.inflate(xhr.responseText, {to:"string"});
B.
String.fromCharCode.apply(null, data2);
C.
for (var i = 0, l = data2.length; i < l; i++)
{
result += String.fromCharCode(parseInt(array[i], 2));
}
所有这些方法都以 JavaScript 字符串的形式带来与原始数据不同的数据。 当我将解压缩的 pako.inflate(xhr.responseText) 保存到文件(使用 a.download 的函数)时,解压缩的文件具有与原始文件完全相同的字节(因此压缩和解压缩可以正常工作,无需任何字节修改)。
我只是尝试做同样的事情,并找到了一种将对象转换为二进制字符串的方法,反之亦然。我只是创建了两个函数,将 JSON 对象转换为二进制字符串,并将二进制字符串转换为 JSON 对象。 covertObjectToBinary 和 ConvertBinaryToObject。
let obj = {a:1}
function covertObjectToBinary(obj) {
let output = '',
input = JSON.stringify(obj) // convert the json to string.
// loop over the string and convert each charater to binary string.
for (i = 0; i < input.length; i++) {
output += input[i].charCodeAt(0).toString(2) + " ";
}
return output.trimEnd();
}
function convertBinaryToObject(str) {
var newBin = str.split(" ");
var binCode = [];
for (i = 0; i < newBin.length; i++) {
binCode.push(String.fromCharCode(parseInt(newBin[i], 2)));
}
let jsonString = binCode.join("");
return JSON.parse(jsonString)
}
console.log('covertObjectToBinary =>', covertObjectToBinary(obj))
console.log('convertBinaryToObject =>', convertBinaryToObject(covertObjectToBinary(obj)))
这并不难。所以只需调用类 TextEncoder() 然后编码方法即可。 例如
new TextEncoder().encode(JSON.stringify('Your object'))
对于解码,只需使用解码方法。