手机端小强原创文章,java小强个人博客站点
当前位置: 首页 >> 理论 >> JAVA加密算法实现用例 密钥一致协议

JAVA加密算法实现用例 密钥一致协议

26950 理论 | 2014-12-27

密钥一致协议是由公开密钥密码体制的奠基人 Diffie 和 Hellman 所提出的一种思想。
代表:指数密钥一致协议 (Exponential Key Agreement Protocol)

 

20100315_937490_image007_666347_30005_0.jpg

 

使用流程介绍:
甲方构建密钥对,将公钥公布给乙方,将私钥保留;双方约定数据加密算法;乙方通过甲方公钥构建密钥对,将公钥公布给甲方,将私钥保留。
甲方使用私钥、乙方公钥、约定数据加密算法构建本地密钥,然后通过本地密钥加密数据,发送给乙方加密后的数据;乙方使用私钥、甲方公钥、约定数据加密算法构建本地密钥,然后通过本地密钥对数据解密。
乙方使用私钥、甲方公钥、约定数据加密算法构建本地密钥,然后通过本地密钥加密数据,发送给甲方加密后的数据;甲方使用私钥、乙方公钥、约定数据加密算法构建本地密钥,然后通过本地密钥对数据解密。
不单单是甲乙双方两方,可以扩展为多方共享数据通讯,这样就完成了网络交互数据的安全通讯!

 

package test;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PublicKey;
import java.security.Security;
import java.security.spec.X509EncodedKeySpec;
import javax.crypto.Cipher;
import javax.crypto.KeyAgreement;
import javax.crypto.SecretKey;
import javax.crypto.interfaces.DHPublicKey;
import javax.crypto.spec.DHParameterSpec;
public class DHKey {
 public static void main(String argv[]) {
  try {
   DHKey my = new DHKey();
   my.run();
  } catch (Exception e) {
   System.err.println(e);
  }
 }
 private void run() throws Exception {
  // A 构建密钥对,公钥给B
  Security.addProvider(new com.sun.crypto.provider.SunJCE());
  KeyPairGenerator aliceKpairGen = KeyPairGenerator.getInstance("DH");
  aliceKpairGen.initialize(512);
  KeyPair aliceKpair = aliceKpairGen.generateKeyPair();
  byte[] alicePubKeyEnc = aliceKpair.getPublic().getEncoded(); // 公开密钥
  
  // B 根据A的公钥构建自己的密钥对,同时把自己生成的公钥给A,通过A的公钥和自己的私钥构建DES的密钥
  KeyFactory bobKeyFac = KeyFactory.getInstance("DH");
  X509EncodedKeySpec x509KeySpec = new X509EncodedKeySpec(alicePubKeyEnc);
  PublicKey alicePubKey = bobKeyFac.generatePublic(x509KeySpec);
  DHParameterSpec dhParamSpec = ((DHPublicKey) alicePubKey).getParams();
  KeyPairGenerator bobKpairGen = KeyPairGenerator.getInstance("DH");
  bobKpairGen.initialize(dhParamSpec);
  KeyPair bobKpair = bobKpairGen.generateKeyPair();
  KeyAgreement bobKeyAgree = KeyAgreement.getInstance("DH");
  bobKeyAgree.init(bobKpair.getPrivate());
  bobKeyAgree.doPhase(alicePubKey, true);
  SecretKey bobDesKey = bobKeyAgree.generateSecret("DES");
  byte[] bobPubKeyEnc = bobKpair.getPublic().getEncoded();
  
  // A 通过本地密钥和A的公钥构建DES密钥,这里还做一个验证
  KeyFactory aliceKeyFac = KeyFactory.getInstance("DH");
  x509KeySpec = new X509EncodedKeySpec(bobPubKeyEnc);
  PublicKey bobPubKey = aliceKeyFac.generatePublic(x509KeySpec);
  KeyAgreement aliceKeyAgree = KeyAgreement.getInstance("DH");
  aliceKeyAgree.init(aliceKpair.getPrivate()); // 秘密密钥
  aliceKeyAgree.doPhase(bobPubKey, true);
  SecretKey aliceDesKey = aliceKeyAgree.generateSecret("DES");
  if (aliceDesKey.equals(bobDesKey))
   System.out.println("A 和 B 的公钥 相同");
  else
   System.out.println("A 和 B 的公钥 不同");
  
  // B 通过密钥加密数据
  Cipher bobCipher = Cipher.getInstance("DES");
  bobCipher.init(Cipher.ENCRYPT_MODE, bobDesKey);
  String bobinfo = "这是B的机密信息";
  System.out.println("B 加密前原文 :" + bobinfo);
  byte[] cleartext = bobinfo.getBytes();
  byte[] ciphertext = bobCipher.doFinal(cleartext);
  
  // A 通过密钥解密数据
  Cipher aliceCipher = Cipher.getInstance("DES");
  aliceCipher.init(Cipher.DECRYPT_MODE, aliceDesKey);
  byte[] recovered = aliceCipher.doFinal(ciphertext);
  System.out.println("A解密 B 的信息 :" + (new String(recovered)));
 }
}

 

推荐您阅读更多有关于“ des 加密 密钥 公钥 一致性 ”的文章

上一篇:抢票,就应该这样 下一篇:模版换回,因不兼容

猜你喜欢

发表评论:

个人资料
blogger

java小强
没有思考,人生的路会越走越难!

搜索
分类
最新微语
  • 8月1日,我已离开奋斗多年的北京。不知道是暂时的离开,还是永久的离别,反正已经离职在家,告别每日上班,每天苦累的煎熬,过一段属于自己的生活。以前是专职工作,现在专职生活。

    2017-08-18 12:47

  • 又弄完一个项目,累成狗,但是感觉又进步不少,除了很多坑已经踩过,做起来也是轻车熟路。同时也认识到,程序不在于你多牛逼,而是在乎你的细节把控度,而细节的关注,是一个优秀程序员必须要注意的。另外,要相信自己,勇敢向前,没人生下来就是成功的,而且,成功的路,比成功本身更重要。

    2017-06-30 09:46

  • 今日北京再次沙尘暴来袭,吃了几年细粮,终于能来口粗粮了,不过大早上看见这场景,还是吓我一跳,不过随后就平静了,毕竟是老朋友了。进公司又发现一股烤糊的味道,真是祸不单行啊,例外都是污染。发了两个口罩,开启保护模式。

    2017-05-04 10:16

  • 今天同学问我,最近还在写代码吗?我想了想,这个问题怎么回答呢,我好像确实很长时间,虽然写了一些,但是主要内容已经不是写代码了。然后再想想,自己也7年多了,这么多年了,我收获了什么,我的目标到底是什么。眼看就奔三了,人生啊,开启感叹模式。

    2017-03-30 22:52

  • 也许大家都已经注意到了,今年的房价,好多地方都是翻了一番,跟着就是,各地房东开始变相涨租。今年之所以搬走,就是为此,这两天同学也是如此。很多房东只认钱,别谈感情,伤钱。而对于这个城市来说,你怎么定位自己,你真把自己当成她的一份子?你来此为何?将来何去何从?自己掂量清楚。

    2016-12-05 10:03

  • 更多»

最新文章
热门文章
随机文章