使用带有公钥的 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 (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...