我使用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())
}
});
}
});
});
});
答案 0 :(得分:0)
wbits
(没有zlib.gunzip
参数)将生成zlib格式,而Node.js中的zlib.compress
期望gzip格式。使用wbits
和zlib.inflate
等于31来获取gzip格式,或者使用Node.js中的contains
来解压缩zlib格式。