作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何通过 yazl 压缩/解压缩缓冲区? https://www.npmjs.com/package/yazl
我不想创建/保存 zip 文件,而只是压缩缓冲区并将其转发到另一个服务。任何示例代码都会有帮助
var yazl = require("yazl");
var buf = fs.readFileSync(__dirname + '/testArchive.txt');
var zipfile = new yazl.ZipFile();
zipfile.addBuffer(buf, "TEMPENTRY");
zipfile.end();
那么现在已经存档了吗?那么如何使用 yauzl 来填充该缓冲区?
最佳答案
这种函数应该会有所帮助,手动检索流的数据包,然后将它们连接到一个缓冲区
中:
function stream2buffer(readableStream) {
return new Promise((resolve, reject) => {
const chunks = [];
readableStream.on('data', (chunk) => {
chunks.push(chunk);
}).on('end', () => {
resolve(Buffer.concat(chunks));
}).on('error', (err) => {
reject(err);
});
});
}
然后您可以在 yazl.ZipFile.outputStream
上使用它,并在 yauzl.ZipFile.openReadStream
回调提供的可读流上使用它。
我的意思更像是在 yazl
的 outputStream
上使用此函数,而不是在要压缩的源文件上。更多类似这样的:
function zipper(mapping) { // mapping is expected to be a Map here
const handler = new yazl.ZipFile(); // yazl = require('yazl');
for (mapItem of mapping) {
if (typeof mapItem[1] === 'string' || mapItem[1] instanceof String) {
handler.addFile(mapItem[1], mapItem[0]);
} else if (mapItem[1] instanceof Buffer) {
handler.addBuffer(mapItem[1], mapItem[0]);
} else if (mapItem[1] instanceof stream.Readable) { // stream = require('stream');
handler.addReadStream(mapItem[1], mapItem[0]);
} else throw new Error('unsupported type');
}
handler.end();
return stream2buffer(handler.outputStream);
}
解压也是一样的:
function unzipper(buffer) {
return new Promise((resolve, reject) => {
unzippedContents = {};
yauzl.fromBuffer(buffer, {lazyEntries: true}, (err, zip) => { // yauzl = require('yauzl')
if (err) return reject(err);
zip.on('entry', (entry) => {
if (/\/$/.test(entry.fileName)) return zip.readEntry(); // no directories
zip.openReadStream(entry, async (err, rs) => {
try {
if (err) throw err;
unzippedContents[entry.fileName] = await stream2buffer(rs);
} catch (err) {
zip.close();
return reject(err);
}
zip.readEntry();
});
}).on('end', () => {
zip.close();
resolve(unzippedContents);
});
zip.readEntry(); // start the process
});
});
}
关于javascript - 如何使用 yazl 压缩缓冲区?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54678668/
如何通过 yazl 压缩/解压缩缓冲区? https://www.npmjs.com/package/yazl 我不想创建/保存 zip 文件,而只是压缩缓冲区并将其转发到另一个服务。任何示例代码都会
我是一名优秀的程序员,十分优秀!