RSA加密算法公钥提取失败求助

wolf_Springs 2013-08-03 04:46:57

Exception in thread "main" java.security.cert.CertificateException: Could not parse certificate: java.io.IOException: DerInputStream.getLength(): lengthTag=109, too big.
at sun.security.provider.X509Factory.engineGenerateCertificate(X509Factory.java:109)
at java.security.cert.CertificateFactory.generateCertificate(CertificateFactory.java:305)
at com.yitong.commons.util.security.RSACerPlus.doEncrypt(RSACerPlus.java:105)
at com.yitong.commons.util.security.RSACerPlus.main(RSACerPlus.java:145)
Caused by: java.io.IOException: DerInputStream.getLength(): lengthTag=109, too big.
at sun.security.util.DerInputStream.getLength(DerInputStream.java:544)
at sun.security.util.DerValue.init(DerValue.java:346)
at sun.security.util.DerValue.<init>(DerValue.java:302)
at sun.security.provider.X509Factory.engineGenerateCertificate(X509Factory.java:104)
... 3 more


做实现对数据进行加密处理的方法时候报出以上异常,查询了一下似乎和数字证书有关.但还是感觉一头雾水.求各位大神帮忙.下面是代码:


public String doEncrypt(String[] str) throws Exception {
//获取公钥
CertificateFactory cff = CertificateFactory.getInstance("X.509");
String filePath = Log4jInit.getCommString(Consts.jks_path);
InputStream in = new FileInputStream(filePath);// 证书文件
//获得公钥文件(报错的地方)
Certificate cf = cff.generateCertificate(in);
PublicKey pk1 = cf.getPublicKey(); // 得到证书文件携带的公钥
Cipher cipher = Cipher.getInstance("RSA");
// 加密模式
cipher.init(Cipher.ENCRYPT_MODE, pk1);
byte[] msg1 = cipher.doFinal(str.toString().getBytes("UTF-8")); // 加密后的数据
return new BASE64Encoder().encode(msg1);
}



...全文
529 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
一次生成了双向证书?
「已注销」 2013-08-03
  • 打赏
  • 举报
回复
长度不对,RSA对长度有要求,比如你用asdfg进行加密,而解密的长度不符合要求,比如asdf,就会出现这个错误。
【课程介绍】     课程目标:             - 有状态登录和无状态登录的区别             - 常见的非对称加密算法和非对称的加密方式             - 老版本只使用jwt进行加密的弊端             - 授权中心的授权流程             - 如何整合网关组件实现jwt安全验证             - 理解什么是公钥什么是私钥      - 深刻理解授权流程什么是有状态? 有状态服务,即服务端需要记录每次会话的客户端信息,从而识别客户端身份,根据用户身份进行请求的处理,典型的设计如tomcat中的session。例如登录:用户登录后,我们把登录者的信息保存在服务端session中,并且给用户一个cookie值,记录对应的session。然后下次请求,用户携带cookie值来,我们就能识别到对应session,从而找到用户的信息。缺点是什么?- 服务端保存大量数据,增加服务端压力- 服务端保存用户状态,无法进行水平扩展- 客户端请求依赖服务端,多次请求必须访问同一台服务器。什么是无状态? 微服务集群中的每个服务,对外提供的都是Rest风格的接口。而Rest风格的一个最重要的规范就是:服务的无状态性,即:- 服务端不保存任何客户端请求者信息- 客户端的每次请求必须具备自描述信息,通过这些信息识别客户端身份带来的好处是什么呢?- 客户端请求不依赖服务端的信息,任何多次请求不需要必须访问到同一台服务- 服务端的集群和状态对客户端透明- 服务端可以任意的迁移和伸缩- 减小服务端存储压力

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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