Java安全类强制转换异常

时间:2012-10-16 12:32:57

标签: java security rsa encryption

您好我是Java安全的初学者,在调用时遇到以下问题:

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

我收到了错误:

java.lang.ClassCastException: com.sun.crypto.provider.RSACipher cannot be cast to javax.crypto.CipherSpi

我的war文件中还有5个用于支付网关加密的jar文件:

  • CRYPTIX-JCE-api.jar文件
  • CRYPTIX-JCE-provider.jar
  • CRYPTIX-消息api.jar文件
  • CRYPTIX-的OpenPGP-provider.jar
  • CRYPTIX-PKI-api.jar文件

如果没有这5个JAR文件,那么 Cipher.getInstance()就可以了,但这是不可能的,因为我需要JAR来进行支付信息加密。

那里的任何人都可以告诉我如何克服这个问题?

3 个答案:

答案 0 :(得分:12)

Powermockito无法增强javax.crypto类,因此您可以在类级别添加以下注释:

@PowerMockIgnore("javax.crypto.*") or @PowerMockIgnore({"javax.crypto" })

答案 1 :(得分:1)

感谢所有的评论和答案。
最后,我将5个Jars从WAR文件移出到服务器Jars库目录并解决了这个问题。
两者之间有java.lang.RuntimeException: NYI
它是使用此处的解决方案解决的:http://javabeanz.wordpress.com/2009/06/11/java-lang-runtimeexception-nyi/ 希望这对任何人都有帮助。
再次感谢!

答案 2 :(得分:0)

在班级@PowerMockIgnore("javax.crypto.*")@PowerMockIgnore({"javax.crypto" })添加此项 添加后如果显示Jce安全异常
您可以下载此文件Java Cryptography Extension (JCE) Unlimited Strength Jurisdiction Policy Files 8并在此路径中替换local_policy jar文件和US_policay jar文件:

C:\Program Files\Java\jdk1.8.0_151\jre\lib\security