gpt4 book ai didi

node.js - 将 Buffer.from() 与 fs.readFileSync() 的内容一起使用可生成包含不同数据的缓冲区

转载 作者:行者123 更新时间:2023-12-05 03:28:30 27 4
gpt4 key购买 nike

let fb = fs.readFileSync(filePath);
let fileData = fb.toString("utf8");
b = Buffer.from(fileData, "utf8");
console.log(fb);
console.log(b);
console.log(b == fb);
console.log(b.toString("utf8") === fb.toString("utf8"));

我将缓冲区转换为 UTF8 字符串,并再次尝试使用 Buffer.from() 取回缓冲区,但我可以看到两个缓冲区不同。但是,如果我再次比较这两个缓冲区的 toString() 结果,它们是相同的。

上述程序的输出

enter image description here

最佳答案

如果 fileData 不是完全合法的 UTF8,则根据 buffer.toString() doc :

If encoding is 'utf8' and a byte sequence in the input is not valid UTF-8, then each invalid byte is replaced with the replacement character U+FFFD.

因此,如果您转换为字符串然后返回缓冲区并且编码不是完美的 utf8 开始,那么该过程是不可逆的,因为一些非法的 utf8 字节将被替换。

比较两个 .toString('utf8') 结果将各自包含相同的“固定”版本(替换字节)。

这里的关键是不要将 Buffer 转换为 utf8 字符串,除非它是真正合法的 utf8 数据。

关于node.js - 将 Buffer.from() 与 fs.readFileSync() 的内容一起使用可生成包含不同数据的缓冲区,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71248293/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com