简体   繁体   English

验证在 JavaCard 上签名的数据时出现 Java BadPaddingException

[英]Java BadPaddingException when verifying data signed on a JavaCard

I'm signing some data on a JavaCard with a cipher, then outputting it into a text file, reading it into a java program and trying to verify it.我正在使用密码在 JavaCard 上签署一些数据,然后将其输出到文本文件中,将其读入 java 程序并尝试验证它。 I keep getting a BadPaddingException.我不断收到 BadPaddingException。

I'm signing it like so on my JavaCard applet:我在我的 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);

And verifying it like this (on my Java program):并像这样验证它(在我的 Java 程序上):

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

When using Cipher.getInstance with "RSA" it defautls to RSA/ECB/RKPCS1Padding does it not?当使用带有“RSA”的 Cipher.getInstance 时,它默认为 RSA/ECB/RKPCS1Padding 不是吗? I'm stuck on how to get rid of the error.我被困在如何摆脱错误上。

Edit: to change encryption and decyrption to sign and verify, for clarity编辑:为了清楚起见,更改加密和解密以签名和验证

Maybe this will help: Which padding is used by javax.crypto.Cipher for RSA .也许这会有所帮助: javax.crypto.Cipher 为 RSA 使用了哪个填充 In short, do not rely on the default, it is best to fully qualify the cipher.简而言之,不要依赖默认值,最好完全限定密码。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM