1

我正在用密码在 JavaCard 上签署一些数据,然后将其输出到文本文件中,将其读入 java 程序并尝试验证它。我不断收到 BadPaddingException。

我在我的 JavaCard 小程序上这样签名:

Cipher cipher = Cipher.getInstance(Cipher.ALG_RSA_PKCS1, false);
cipher.init(key.getPrivate(), Cipher.MODE_ENCRYPT);
short sigCipherLength = cipher.doFinal(inputArray, inputOffset, inputLength, outputArray, outputOffset);

并像这样验证它(在我的 Java 程序上):

Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");
cipher.init(Cipher.DECRYPT_MODE, publicKey);
byte[] decryptedText = cipher.doFinal(inputArray);

当使用带有“RSA”的 Cipher.getInstance 时,它​​默认为 RSA/ECB/RKPCS1Padding 不是吗?我被困在如何摆脱错误上。

编辑:为了清楚起见,更改加密和解密以签名和验证

4

1 回答 1

0

也许这会有所帮助:javax.crypto.Cipher 为 RSA 使用了哪个填充。简而言之,不要依赖默认值,最好完全限定密码。

于 2021-03-23T06:24:39.373 回答