问题描述
- 安卓端与服务端用的同一个RSA工具类
- 安卓端自己加解密正常,服务端加解密正常,两端秘钥相同
- 安卓端加密后传到服务端解密异常,且两端密文一致
- 服务端解密异常信息为:
javax.crypto.BadPaddingException : Decryption error
问题原因
- RSA工具类都使用了
import javax.crypto.Cipher;
虽然包名、类名都一致,但是实际使用的类却不一样:
安卓端:
java服务端:
- 进入类,二者代码确实不一致
安卓端:
java服务端:
3. 二者使用的privoder不一致
安卓端:
java服务端:
4. com.sun.crypto.provider.RSACipher中paddingType默认为“PKCS1Padding”
问题解决
安卓端实例化Cipher时,指定paddingType
Cipher cipher = Cipher.getInstance("RSA/None/PKCS1Padding");