微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用 openpgp-js 解码 Java Bouncy Castle 编码的 PGP 消息:未找到公钥加密会话密钥包

如何解决使用 openpgp-js 解码 Java Bouncy Castle 编码的 PGP 消息:未找到公钥加密会话密钥包

我正在尝试使用适用于 Java 的 Bouncy Castle 库解码在其他应用程序中创建的自定义 PGP 消息。根据params,它使用SHA512进行散列,使用RSA进行编码和解码。密钥长度为 1024 位。

const publicKeyArmored = `-----BEGIN PGP PUBLIC KEY BLOCK-----
Version: BCPG v1.65

...
-----END PGP PUBLIC KEY BLOCK-----
`;

const privateKeyArmored = `-----BEGIN PGP PRIVATE KEY BLOCK-----
Version: BCPG v1.65

...
-----END PGP PRIVATE KEY BLOCK-----
`;
const passphrase = 'password';

const encrypted = `-----BEGIN PGP MESSAGE-----
Version: BCPG v1.65

...
-----END PGP MESSAGE-----
`;

async function run() {

    const publicKey = await openpgp.readKey({ armoredKey: publicKeyArmored })
    const privateKey = await openpgp.decryptKey({
        privateKey: await openpgp.readPrivateKey({ armoredKey: privateKeyArmored }),passphrase,config: { minRSABits: 1024,preferredHashAlgorithm: openpgp.enums.hash.sha512 }
    })

    const message = await openpgp.readMessage({ armoredMessage: encrypted })

    const options = {
        message: message,decryptionKeys: privateKey
    }

    const decrypted = await openpgp.decrypt(options);

    console.log(decrypted.data)
}

代码应该能够解码由 BouncyCastle 库使用给定公钥编码的 PGP 消息。我们还有私人密码和正确的密码。

如果我们使用这个密钥对来编码,然后完全使用 openpgp-js 解码自定义文本,一切正常,但是当我们尝试使用给定的密钥对解码现有消息时(当然,消息是用相同的密钥对编码的) ),我们在解码时出错:

UnhandledPromiseRejectionWarning: Error: Error decrypting message: No public key encrypted session key packet found.
    at cc.decryptSessionKeys (C:\dev\other\encryption\node_modules\openpgp\dist\node\openpgp.min.js:2:335642)
    at cc.decrypt (C:\dev\other\encryption\node_modules\openpgp\dist\node\openpgp.min.js:2:334457)
    at Object.exports.decrypt (C:\dev\other\encryption\node_modules\openpgp\dist\node\openpgp.min.js:16:132458)

关于此错误的其他问题实际上是关于旧 API,问题通常很简单:就像在解密参数中设置密码一样,使库认为消息是用密码编码的,而不是用密钥对编码的。

>

在此先感谢您的帮助!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?