java RSA 在win和linux解密的明文长度不一致,请高手帮忙看看

mylife的博客 2015-08-01 06:48:23
我就是使用下面的方法进行解密的,在win平台解密后的字符串是a123456781231:linux平台解密后的字符串是xxxxxxxxxxxxxxxxxxxxxxxa123456781231 (xx是一些乱码),求教大神

public static byte[] decryptByPrivateKey(byte[] data, String key) throws Exception{
// 对密钥解密
byte[] keyBytes = decryptBASE64(key);

// 取得私钥
PKCS8EncodedKeySpec pkcs8KeySpec = new PKCS8EncodedKeySpec(keyBytes);
KeyFactory keyFactory = KeyFactory.getInstance(“RSA”);
Key privateKey = keyFactory.generatePrivate(pkcs8KeySpec);

// 对数据解密
Cipher cipher = Cipher.getInstance(keyFactory.getAlgorithm());
cipher.init(Cipher.DECRYPT_MODE, privateKey);

return cipher.doFinal(data);
}

使用http://snowolf.iteye.com/blog/379860这个链接上别人写的方法。
...全文
369 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
tianfang 2015-08-05
  • 打赏
  • 举报
回复
问问系统管理员是否可以升级服务器操作系统和jdk 另外,这么老的服务器,性能比现在的x86服务器差很多了
tianfang 2015-08-05
  • 打赏
  • 举报
回复
jdk版本太老了
mylife的博客 2015-08-04
  • 打赏
  • 举报
回复
在windows上可以使用 Cipher.getInstance("RSA/ECB/PKCS1Padding"); 但在linux上使用Cipher.getInstance("RSA/ECB/PKCS1Padding");就报错了,Cannot find any provider supporting RSA/ECB/PKCS1Padding。 在linux上怎么安装这些支持类包? linux环境是SunOS,jdk是1.3.1版本。
mylife的博客 2015-08-04
  • 打赏
  • 举报
回复
Cannot find any provider supporting RSA/ECB/PKCS1Padding
tianfang 2015-08-02
  • 打赏
  • 举报
回复
padding缺省值不同,get Instance 时候加上padding值
tianfang 2015-08-02
  • 打赏
  • 举报
回复
padding缺省值不同,get Instance 时候加上padding值
tianfang 2015-08-02
  • 打赏
  • 举报
回复
padding缺省值不同,get Instance 时候加上padding值

67,512

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧