Diffie-Hellman密钥交换算法

0x01 Diffie-Hellman密钥交换概述

Diffie-Hellman密钥交换是一种安全交换密钥的方法,可以让双方在不泄漏密钥的情况下,德出一个密钥。以Whitfield Diffie和Martin Hellman的名字共同命名。
Diffie-Hellman密钥交换是Ralph Merkle构想的第一个公钥协议之一,由 Diffie 和 Hellman 于 1976 年出版,这是最早提出私钥和相应公钥概念的公开著作。可以让双方在不泄漏密钥的情况下协商出一个密钥来

传统上,两方之间的安全加密通信要求他们首先通过某种安全的物理方式交换密钥,例如由受信任的信使传输纸质密钥列表。
Diffie-Hellman密钥交换方法允许彼此双方在不安全的通道上共同建立共享密钥。

总结来说就是Diffie-Hellman密钥交换方法在发送和接收双方见建立了一个“秘密通信方法”,目的是为了能够在公共平台发送秘密数据。

wikipedia给了一个非常好的例子,简单解读一下可以非常清楚Diffie-Hellman密钥交换的本质。

可以看出通信双方为:Alice,Bob
Alice和Bob先共同有一个相同的颜色,Alice通过自己的私有颜色获得了可以公开的颜色,bob也通过自己的私有颜色获得了可以公开的颜色,之后二者互换,Alice和Bob通过自己的私有颜色去处理接收到的颜色,最终获得相同颜色。

0x02 Diffie-Hellman 密钥交换的历史

Diffie-Hellman 密钥交换可以追溯到 1970 年代,在那个年代,Whitfield Diffie 和 Martin Hellman 发表了他们的论文《密码学新方向》,从此这个新技术又被称为Diffie-Hellman 密钥交换。

这项工作的灵感部分来自 Ralph Merkle 的早期发展。Merkle谜题,接受者会随机选择一个谜题来解决,然后付出必要的努力来完成它。一旦解决了这个难题,就会向接收者显示一个标识符和一个会话密钥。然后收件人将标识符发送回原始发件人,这让发件人知道已解决了哪个难题。

0x02 Diffie-Hellman密钥交换例子

有两个公开的参数,一个素数p,一个原根g
假设用户A和B希望交换一个密钥,用户A选择一个作为私有密钥的随机数a
计算出Akey=g^a mod p,并将Akey发送给用户B
用户B随机选取b,计算出Bkey=g^b mod p,并将Bkey发送给用户A
此时,用户A知道p,g,a,Bkey
用户A通过计算得到共享密钥=Bkey^a mod p
用户B知道p,g,b,Akey
用户B通过计算得到共享密钥=Akey^b mod p
而用户A和用户B计算得到的共享密钥是一样的
共享密钥还可以这样算key=g^(a*b) mod p

也就是A得到的是:


B得到的是:

0x03 Diffie-Hellman安全性

尽管 Diffie-Hellman 已被证明在正确实施时具有很强的抗攻击性,但仍存在安全问题,除了暴力破解、离散对数或量子计算方面的突破之外,Diffie-Hellman 的用户可能容易受到少数依赖于利用计算环境的攻击,即所谓的边信道攻击。

Diffie-Hellman密钥交换算法在其基本形式中最严重的限制是缺乏身份验证,单独使用Diffie-Hellman密钥交换的通信很容易受到中间人攻击。

理想情况下,Diffie-Hellman 应该与公认的身份验证方法(例如数字签名)结合使用,以通过公共通信介质验证用户的身份。Diffie-Hellman密钥交换非常适合用于数据通信,但较少用于长时间存储或归档的数据。

References:
Diffie-Hellman密钥交换算法(非专业只讲过程)_VVeaker的博客-CSDN博客
What is Diffie-Hellman Key Exchange? - Definition from WhatIs.com

  • 15
    点赞
  • 58
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lmn_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值