使用openpgp js解码java bouncy castle编码的pgp消息:未找到公钥加密的会话密钥包

gj3fmq9x  于 2021-09-29  发布在  Java
关注(0)|答案(0)|浏览(311)

我试图用bouncy castle library for java解码在其他应用程序中创建的自定义pgp消息。根据参数,使用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的,问题通常很简单:比如密码是在解密参数中设置的,使库认为消息是用密码编码的,而不是用密钥对。
提前感谢您的帮助!

暂无答案!

目前还没有任何答案,快来回答吧!

相关问题