为了账号安全,请及时绑定邮箱和手机立即绑定

java.security.NoSuchAlgorithmException: Unsupported secret key algorithm: DES

java.security.NoSuchAlgorithmException: Unsupported secret key algorithm: DES

                at com.sun.crypto.provider.DHKeyAgreement.engineGenerateSecret(DHKeyAgreement.java:387)

                at javax.crypto.KeyAgreement.generateSecret(KeyAgreement.java:648)

我使用 JDK1.8,这是什么问题?

代码是看视频写的,并且也参考了评论中的部分代码。运行都是这个问题。

正在回答

4 回答

由于JDK版本不同,在Java 8 update 161版本以后就会出现此问题,根本原因还是DH密钥长度至少为512位,而DES算法密钥没有这么长,密钥长度不一致引起的。

解决方法:

配置JVM的系统变量:-Djdk.crypto.KeyAgreement.legacyKDF=true

https://img1.sycdn.imooc.com//5bbdae8800016f9210920689.jpg

4 回复 有任何疑惑可以回复我~
#1

五行_缺钱

牛逼啊 o( ̄▽ ̄)d
2019-05-17 回复 有任何疑惑可以回复我~

我的也是,怎么解决的 啊!

java.security.NoSuchAlgorithmException: Unsupported secret key algorithm: DES

at com.sun.crypto.provider.DHKeyAgreement.engineGenerateSecret(DHKeyAgreement.java:387)

at javax.crypto.KeyAgreement.generateSecret(KeyAgreement.java:648)

at com.wbs.security.dh.ImoocDH.jdkDH(ImoocDH.java:50)

at com.wbs.security.dh.ImoocDH.main(ImoocDH.java:24)


47        KeyAgreement receiverKeyAgreement = KeyAgreement.getInstance("DH");

48        receiverKeyAgreement.init(receiverPrivateKey);

49        receiverKeyAgreement.doPhase(receiverPublicKey, true);

50        SecretKey receiverDesKey = receiverKeyAgreement.generateSecret("DES");


0 回复 有任何疑惑可以回复我~

jdk版本问题

0 回复 有任何疑惑可以回复我~

这里的 DES。

//3.密钥构建

KeyAgreement receiveKeyAgreement = KeyAgreement.getInstance("DH");

receiveKeyAgreement.init(receivePrivateKey);

receiveKeyAgreement.doPhase(receivePublicKey, true);

SecretKey receiveDesKey = receiveKeyAgreement.generateSecret("DES");

1 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
JAVA实现非对称加密
  • 参与学习       27470    人
  • 解答问题       36    个

非对称加密算法在JAVA中的实现,了解非对称加密算法应用场景

进入课程

java.security.NoSuchAlgorithmException: Unsupported secret key algorithm: DES

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信