我有一个ArrayBuffer,它通过使用Frida读取内存返回。我正在将ArrayBuffer转换为字符串,然后使用TextDecoder和TextEncoder返回到ArrayBuffer,但是结果在这个过程中被改变了。解码和重编码后的ArrayBuffer长度总是变大.是否有一种广泛的字符解码方式?
如何在不丢失完整性的情况下将ArrayBuffer解码为字符串,然后返回到ArrayBuffer?
示例代码:
var arrayBuff = Memory.readByteArray(pointer,2000); //Get a 2,000 byte ArrayBuffer
console.log(arrayBuff.byteLength); //Always returns 2,000
var textDecoder = new TextDecoder("utf-8");
var textEncoder = new TextEncoder("utf-8");
//Decode and encode same data without making any changes
var decoded = textDecoder.decode(arrayBuff);
var encoded = textEncoder.encode(decoded);
console.log(encoded.byteLength); //Fluctuates between but always greater than 2,000发布于 2018-05-06 09:40:43
TextDecoder和TextEncoder设计用于处理文本。若要将任意字节序列转换为字符串并返回,最好将每个字节视为单个字符。
var arrayBuff = Memory.readByteArray(pointer,2000); //Get a 2,000 byte ArrayBuffer
console.log(arrayBuff.byteLength); //Always returns 2,000
//Decode and encode same data without making any changes
var decoded = String.fromCharCode(...new Uint8Array(arrayBuff));
var encoded = Uint8Array.from([...decoded].map(ch => ch.charCodeAt())).buffer;
console.log(encoded.byteLength);decoded字符串将具有与输入缓冲区完全相同的长度,可以很容易地使用正则表达式、字符串方法等操作。但请注意,占用内存中两个或两个以上字节的Unicode字符(例如"π")将无法识别,因为它们将导致与每个字节的代码对应的字符的串联。
https://stackoverflow.com/questions/50198017
复制相似问题