这是值得铭记的时刻,我纠结了一下午都没有找到问题
我的工程demo地址(demo里这句代码没有改,你用的时候直接改下就ok了)
今天在用Rsa解密服务端的数据时,碰到了部分乱码的问题,虽然能解密出正确的数据但是里面会多出一堆乱码.一开始以为是编码的问题,可是全都设置成了utf-8也是不行;
最后的解决方法如下:
- 移动端私钥解密
在移动端获取解密的Cipher类时要使用Cipher.getInstance(“RSA/ECB/PKCS1Padding”);
移动端的RSAUtils中有这样一个方法:
![]()
/**
* 用私钥解密
*
* @param encryptedData
* 经过encryptedData()加密返回的byte数据
* @param privateKey
* 私钥
* @return
*/
public static byte[] decryptData(byte[] encryptedData, PrivateKey privateKey)
{
try
{
//这句和java端不一样
Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");
cipher.init(Cipher.DECRYPT_MODE, privateKey);
return cipher.doFinal(encryptedData);
} catch (Exception e)
{
return null;
}
}
在后端使用Cipher.getInstance(“RSA”);来获取.
java后端使用这种方式获取Cipher


本文详细介绍了在移动端和后端使用RSA解密时遇到的乱码问题及解决方案。通过调整Cipher实例化方式,成功解决了乱码问题,确保了解密数据的正确性。
630

被折叠的 条评论
为什么被折叠?



