Zlib:Node.js无法从python中提取压缩数据

时间:2017-12-05 11:40:48

标签: javascript python node.js sqlite zlib

我使用python压缩字符串数据并将数据存储在sqlite3中。对于我的项目,我还需要使用node.js来提取数据。问题是,当我尝试这样做。我从node.js收到错误:

{错误:错误的标题检查     在Gunzip.zlibOnError(zlib.js:153:15)errno:-3,代码:'Z_DATA_ERROR'}

我尝试使用Base64和utf8在Python中编码字符串。两者都没有区别。

在JavaScript中我试图跳过一些编码数据,以便我可以克服头部检查问题。这也是徒劳的。

这是python中的压缩代码

import zlib, base64
import time
text = 'STACK OVERFLOW STACK OVERFLOW STACK OVERFLOW STACK OVERFLOW '
textToBytes = text.encode('utf-8')
code =  zlib.compress(textToBytes)

code = base64.b64encode(code)
print('code in base64:', code)

timestamp = time.time()
#Store in database
conn = sqlite3.connect('testsDummy.db')
c = conn.cursor()

c.execute("CREATE TABLE IF NOT EXISTS tests (id INTEGER PRIMARY KEY, timestamp REAL, code TEXT)")
conn.commit()
c.execute("INSERT INTO  tests (code ,timestamp) VALUES (?,?)",(code ,timestamp))
conn.commit()
conn.close()

现在这是node.js中的代码

function toArrayBuffer(buffer) {
  var arrayBuffer = new ArrayBuffer(buffer.length);
  var view = new Uint8Array(arrayBuffer);
  for (var i = 0; i < buffer.length; ++i) {
    view[i] = buffer[i];
  }
  return arrayBuffer;
}

app.get('/download/logfile/:timestamp', (req, res) => {
  var zlib = require('zlib');

  var db = new sqlite3.Database(path.join(__dirname, 'dependencies', 'testsDummy.db'));
  db.serialize(() => {
    db.all('SELECT code FROM tests WHERE timestamp=' + req.params.timestamp, (error, tests) => {
      db.close();

      if (tests[0].code== '' || tests[0].code== null) {
        res.send('No qdxm data collected.');
      }
      else {
        console.log(tests[0].code)
        var arrayBuffer = toArrayBuffer(Buffer.from(tests[0].code, 'base64'));
        zlib.gunzip(Buffer.from(arrayBuffer, 4), function (err, uncompressedMessage) {
          if (err) {
            console.log(err)
            res.send();
          }
          else {
            res.json({ uncompressedMessage: uncompressedMessage.toString() })
            console.log(uncompressedMessage.toString())
          }
        });
      }
    });
  });
});

1 个答案:

答案 0 :(得分:0)

Python中的

wbits(没有zlib.gunzip参数)将生成zlib格式,而Node.js中的zlib.compress期望gzip格式。使用wbitszlib.inflate等于31来获取gzip格式,或者使用Node.js中的contains来解压缩zlib格式。

相关问题