java.security.InvalidKeyException: Illegal key size or default
parameters
at javax.crypto.Cipher.checkCryptoPerm(Cipher.java:1011)
at javax.crypto.Cipher.implInit(Cipher.java:786)
at javax.crypto.Cipher.chooseProvider(Cipher.java:849)
at javax.crypto.Cipher.init(Cipher.java:1213)
at javax.crypto.Cipher.init(Cipher.java:1153)
at cn.security.conpleteAlg.DHCoder.encrypt(DHCoder.java:82)
at cn.security.junitTest.DHCoderTest.test(DHCoderTest.java:40)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native
Method)
出现上述现象是因为美国的出口管制限制,Java发布的运行环境包中的加解密有一定的限制。比如默认不允许256位密钥的AES加解密,解决方法就是修改策略文件。
官方网站提供了JCE无限制权限策略文件的下载:将两个jar文件也放到%JDK_HOME%\jre\lib\security下。
如果是使用MyEclpse等工具编写java文件,则需要将MyEclipse的JRE编译环境换位本地安装目录的JRE.
或者直接将\MyEclipse Professional 2014\binary\com.sun.java.jdk7.win32.x86_64_1.7.0.u45\jre\lib\security目录下的文件覆盖,就可以编译通过。
java.security.InvalidKeyException: Illegal key size or default parameters
原文地址:http://blog.csdn.net/u014682413/article/details/42267137