您好我是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文件:
如果没有这5个JAR文件,那么 Cipher.getInstance()就可以了,但这是不可能的,因为我需要JAR来进行支付信息加密。
那里的任何人都可以告诉我如何克服这个问题?
答案 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