问题描述
我写了一个方法,它应该取一个目录,将它打包成一个 .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 (将#修改为@)