我试图测试是否通过Snappy压缩文本。我使用的是Node.JS https://github.com/kesla/node-snappy库。
感谢此answer以获取有关从文件中读取的帮助。
$cat Decompress.js
var snappy = require('snappy');
var fs = require('fs');
var filename = './snappy_compressed_docs/snappy_compressed_file'
fs.readFile(filename, 'utf8', function(err, data) {
if (err) throw err;
console.log("done printing data. 'typeof data':", typeof data);
console.log("snappy: ", snappy);
snappy.isValidCompressed(data, function(e, result) {
if(e) { console.log("error!", e); throw e; }
console.log("snappy.isValidCompressed:", result);
});
});
这是我得到的:
$node Decompress.js
done printing data. 'typeof data': string
snappy: { compress: [Function],
isValidCompressed: [Function: isValidCompressed],
uncompress: [Function] }
Assertion failed: (obj->HasIndexedPropertiesInExternalArrayData()),
function Length, file ../src/node_buffer.cc, line 115.
Abort trap: 6
Assertion failed...
部分发生了什么?
答案 0 :(得分:3)
这里的问题是isValidCompressed
需要缓冲区,而不是字符串。
基于失败的断言,我们可以看到我们在“外部”数组数据中寻找奇怪的属性,这意味着某些地方需要比JavaScript String更原始的东西。如果我们查看node-snappy的isValidCompressed
bindings,我们会看到它将其输入数据视为node::Buffer
。由于typeof data
给了我们string
,我们可能没有正确的数据类型。
这里的解决方案是将'utf8'
参数放到readFile
,它将数据作为原始缓冲区而不是尝试将其转换为字符串。