欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

java 非对称加密算法DH实现详解

时间:2021-09-09 09:52:07|栏目:JAVA代码|点击:

非对称加密算法是相对于对称加密算法来说的,对于对称加密算法请查阅之前的总结,今天为大家介绍一下DH算法,DH是一种密钥交换算法,接收方根据发送方加密时的密钥,生成接收方解密密钥。下面就一起来学习一下吧:

初始化发送方密钥:

KeyPairGenerator sendKeyPairGenerator = KeyPairGenerator.getInstance("DH");
      sendKeyPairGenerator.initialize(512);
      KeyPair sendKeyPair = sendKeyPairGenerator.generateKeyPair();
      byte[] sendPublicKeyEnc = sendKeyPair.getPublic().getEncoded();//生成发送方公钥,发送给接收方(网络、文件...)

初始化接收方密钥:

KeyFactory receiverKeyFactory = KeyFactory.getInstance("DH");
      X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(sendPublicKeyEnc);
      PublicKey receivePublicKey = receiverKeyFactory.generatePublic(x509EncodedKeySpec);
      DHParameterSpec dhParameterSpec = ((DHPublicKey)receivePublicKey).getParams();
      KeyPairGenerator receiverKeyPairGenerator = KeyPairGenerator.getInstance("DH");
      receiverKeyPairGenerator.initialize(dhParameterSpec);
      KeyPair receiverKeyPair = receiverKeyPairGenerator.generateKeyPair();
      PrivateKey receiverPrivateKey = receiverKeyPair.getPrivate();
      byte[] receiverPublicKeyEnc = receiverKeyPair.getPublic().getEncoded();

构建接收方密钥:

KeyAgreement receiverKeyAgreement = KeyAgreement.getInstance("DH");
      receiverKeyAgreement.init(receiverPrivateKey);
      receiverKeyAgreement.doPhase(receivePublicKey, true);
      
      SecretKey receiverDESKey = receiverKeyAgreement.generateSecret("DES");//接收方Key

构建发送方密钥:

KeyFactory sendKeyFactory = KeyFactory.getInstance("DH");
      x509EncodedKeySpec = new X509EncodedKeySpec(receiverPublicKeyEnc);
      PublicKey sendPublicKey = sendKeyFactory.generatePublic(x509EncodedKeySpec);
      
      KeyAgreement sendKeyAgreement = KeyAgreement.getInstance("DH");
      sendKeyAgreement.init(sendKeyPair.getPrivate());
      sendKeyAgreement.doPhase(sendPublicKey, true);
      
      SecretKey sendDESKey = sendKeyAgreement.generateSecret("DES");//发送方Key

发送方加密:

Cipher sendCipher = Cipher.getInstance("DES");
      sendCipher.init(Cipher.ENCRYPT_MODE, sendDESKey);
      byte[] sendResult = sendCipher.doFinal(src.getBytes());
      System.out.println("sendResult :"+Hex.encodeHexString(sendResult));

接收方解密:

Cipher receiverCipher = Cipher.getInstance("DES");
      receiverCipher.init(Cipher.DECRYPT_MODE, receiverDESKey);
      byte[] receiverResult = receiverCipher.doFinal(sendResult);
      System.out.println("receiverResult : "+new String (receiverResult));

基于密钥交换的非对称加密算法(DH),到这里就总结完毕了。

上一篇:Java 中二进制转换成十六进制的两种实现方法

栏    目:JAVA代码

下一篇:spring cloud整合ribbon问题及解决方案

本文标题:java 非对称加密算法DH实现详解

本文地址:http://www.codeinn.net/misctech/173712.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有