【发布时间】:2021-07-11 15:33:56
【问题描述】:
假设我有一个字符串
"020000009B020000C0060000"
我想把它变成一个字符串,这样如果它被保存为一个文件并在十六进制编辑器中打开它,它将显示与我输入的相同的十六进制。 我该怎么做呢? 我从来不需要使用缓冲区或其他任何东西,但在尝试这样做时,我似乎不得不这样做,而且我真的不知道自己在做什么。
(或者我是否应该使用缓冲区——我一直在寻找几个小时,我能找到的只是使用缓冲区的答案,所以我只是举了他们的例子,但没有任何效果)
我把十六进制字符串变成了缓冲区
function hexToBuffer(hex) {
let typedArray = new Uint8Array(hex.match(/[\da-f]{2}/gi).map(function (h) {
return parseInt(h, 16)
}))
return typedArray
}
这似乎有效,因为记录 hexToBuffer("020000009B020000C0060000").buffer 它返回的内容给了我这个:
ArrayBuffer {
[Uint8Contents]: <02 00 00 00 9b 02 00 00 c0 06 00 00>,
byteLength: 12
}
与我输入的十六进制相同,所以它似乎工作正常, 然后将数组缓冲区变成一个字符串,我这样做了。
let dataView = new DataView(buffer);
let decoder = new TextDecoder('utf-8');
let string = decoder.decode(dataView)
为了测试它是否有效,我将它保存到一个文件中。
fs.writeFileSync(__dirname+'/test.txt', string)
在十六进制编辑器中打开 test.txt 会显示不同的数据:
02000000EFBFBD020000EFBFBD060000
如果我这样做
fs.writeFileSync(__dirname+'/test.txt', hexToBuffer("020000009B020000C0060000"))
然后我得到正确的数据-但是如果我用 fs 读取文件然后添加到它,它的值又不一样了。
let test = fs.readFileSync(__dirname+'/test.txt', 'utf8)
let example2 = test+'example'
fs.writeFileSync(__dirname+'/test.txt', example2)
现在 test.txt 以 02000000EFBFBD020000EFBFBD060000 开头,而不是 020000009B020000C0060000。我该怎么办?
【问题讨论】:
-
你不应该把它变成一个字符串,只需将缓冲区按原样保存到文件中。但是,您不能以您所做的方式“添加到它”,因为您指定将其解码为 utf8 ......这将改变它,因为它不是真正的 utf8。相反,只使用缓冲区,永远不要将它们转换为字符串。