java des 使用KeyGenerator.init()方法:Exception in thread "main" java.security.

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)

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    56
DESede    112或168
RC2    128
RC4    128
RC5    128
RSA    128

all others    128

猜你喜欢

转载自blog.csdn.net/kzcming/article/details/80705873