如何解决如何从 openpgp.encrypt 流式传输输出?
我写了一个方法,它应该取一个目录,将它打包成一个 .tgz 文件,然后使用 openpgp v5.0.0-5 对其进行加密。所有这些都是通过流完成的,因为目录及其内容可能是任意大小。
async encodeMessage(privkey,pubkey,passphrase,dstfile,subdir,callback = null) {
await tar.c({ gzip: true },[subdir]).pipe(fs.createWriteStream(subdir + ".tgz"));
var pubkey = await openpgp.readKey({ armoredKey: pubkey });
var privkey = await openpgp.decryptKey({
privateKey: await openpgp.readPrivateKey({ armoredKey: privkey }),passphrase
});
var messageStream = await openpgp.createMessage({ binary: fs.createReadStream("./" + subdir + ".tgz") });
var output = fs.createWriteStream(subdir + ".msg",{ encoding: "binary" });
var encrypted = await openpgp.encrypt({
message: messageStream,format: "binary",encryptionKeys: pubkey,signingKeys: privkey,});
await encrypted.pipe(output);
}
据我所知,一切正常,直到最后一步。我只得到前 442 个字节,而不是得到预期的加密输出文件。我做错了什么?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。