如何解决使用带有公钥的 OpenPGP.js 加密字符串
您好,有人可以帮我解决使用公钥加密文本时出错的问题吗? 加密消息时出错:找不到主要用户
我存储装甲密钥并读取它并生成文本以创建 .csv 文件。当我收到错误时,我正在尝试加密。 一些示例代码:
const readFileAsync = util.promisify(fs.readFile);
let publicKeyStream = await readFileAsync(PUBLIC_CREDENTIALS_PATH,'utf8');
let publicKey = await openpgp.readKey( { armoredKey : publicKeyStream});
let privateKeyStream = await readFileAsync(PRIVATE_CREDENTIALS_PATH,'utf8');
let privateKey = await openpgp.readKey( {armoredKey : privateKeyStream });
console.log(csvContent);
let textToEncrypt = openpgp.Message.fromText(csvContent);
csvContent = await openpgp.encrypt({
message: textToEncrypt,publicKeys: publicKey,privateKeys: privateKey,});
作为奖励,我也无法解密。我从 SFTP 服务器获取一个文件并将其复制到本地,读取它并尝试对其进行解密。此错误内容如下: 解析时出错。此消息/密钥可能不符合有效的 OpenPGP 格式。
我发现的大多数答案似乎都是针对具有不同语法的旧版 OpenPGP。
我能够使用相同的密钥文件和 Kleopatra 成功解密和加密文件
let PrivateKeyStream = await readFileAsync(CREDENTIALS_PATH,'utf8');
let PrivateKey = await openpgp.readKey( {armoredKey : PrivateKeyStream })
const result = await SFTPClient.fastGetFile(remotePath,localPath,credentials);
const encryptedData = await readFileAsync(localPath,'utf8')
let encryptedMessage = await openpgp.readMessage( { binaryMessage : encryptedData})
const { data: decrypted } = await openpgp.decrypt({
message: encryptedMessage,privateKeys : [PrivateKey],});
非常感谢!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。