检查文件是否通过Snappy压缩

时间:2015-02-18 20:53:42

标签: node.js snappy

我试图测试是否通过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...部分发生了什么?

1 个答案:

答案 0 :(得分:3)

这里的问题是isValidCompressed需要缓冲区,而不是字符串。

基于失败的断言,我们可以看到我们在“外部”数组数据中寻找奇怪的属性,这意味着某些地方需要比JavaScript String更原始的东西。如果我们查看node-snappy的isValidCompressed bindings,我们会看到它将其输入数据视为node::Buffer。由于typeof data给了我们string,我们可能没有正确的数据类型。

这里的解决方案是将'utf8'参数放到readFile,它将数据作为原始缓冲区而不是尝试将其转换为字符串。