问题描述

  1. 安卓端与服务端用的同一个RSA工具类
  2. 安卓端自己加解密正常,服务端加解密正常,两端秘钥相同
  3. 安卓端加密后传到服务端解密异常,且两端密文一致
  4. 服务端解密异常信息为:
javax.crypto.BadPaddingException : Decryption error

问题原因

  1. RSA工具类都使用了
import javax.crypto.Cipher;

虽然包名、类名都一致,但是实际使用的类却不一样:
安卓端:
安卓端java服务端:java服务端

  1. 进入类,二者代码确实不一致

安卓端:
安卓端java服务端:java服务端
3. 二者使用的privoder不一致

安卓端:
安卓端
java服务端:
java服务端
4. com.sun.crypto.provider.RSACipher中paddingType默认为“PKCS1Padding”
在这里插入图片描述

问题解决

安卓端实例化Cipher时,指定paddingType

Cipher cipher = Cipher.getInstance("RSA/None/PKCS1Padding");
Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐