Exception in thread "main" java.security.InvalidParameterException: Wrong keysize: must be equal to 56
at com.sun.crypto.provider.DESKeyGenerator.engineInit(DESKeyGenerator.java:90)
at javax.crypto.KeyGenerator.init(KeyGenerator.java:517)
at javax.crypto.KeyGenerator.init(KeyGenerator.java:494)
at test.java.security.TestKeyGenerator.main(TestKeyGenerator.java:16)
异常解释
问题点:
附录
jca 附录A; 对应算法允许的密钥长度
Algorithm Maximum Keysize
DES 64
DESede *
RC2 128
RC4 128
RC5 128
RSA *
all others 128
at com.sun.crypto.provider.DESKeyGenerator.engineInit(DESKeyGenerator.java:90)
at javax.crypto.KeyGenerator.init(KeyGenerator.java:517)
at javax.crypto.KeyGenerator.init(KeyGenerator.java:494)
at test.java.security.TestKeyGenerator.main(TestKeyGenerator.java:16)
java des 使用KeyGenerator.init()方法:Exception in thread "main" java.security.InvalidParameterException:
异常解释
在javadoc 中发现该异常描述:当将无效参数传递给某个方法时抛出此异常,设计该异常供 JCA/JCE 引擎类使用。
在javadoc中 KeyGenerator.init()方法描述:
抛出:InvalidParameterException - 如果密钥大小错误或不受支持。
问题点:
发现是初始化KeyGenerator对象是出错 keyGenerator.init(int size)报错已经很明显,des指定生成的长度只能为56位,一般ase则为128位,将init传入参数修改为对应的算法允许的密钥长度即可
注意:一般java 的算法生成的密钥长度都有限制是因为jce框架做了限制,如果要解除限制可在oracle官网下载对应的key策略文件即可生成长度无限制的密钥
附录
jca 附录A; 对应算法允许的密钥长度
Algorithm Maximum Keysize
DES 64
DESede *
RC2 128
RC4 128
RC5 128
RSA *
all others 128