计算机网络——DH密钥交换

        之前的文章说的都是RSA加密形式加密密钥,但是这类加密方式都有一个共性问题,你就是前向保密性。当服务端的私钥泄漏了之后,那么所有数据都会泄露,所以DH密钥交换方式就诞生了。

        DH密钥交换让通信双方都拥有一对密钥和公钥,当拥有对方的公钥后,可以结合自己的私钥计算出共同的密钥,并以此来做后续通信。

DH密钥交换涉及离散对数:

        

        有了以上这个公式,一职a,i,p时求b是一个十分简单的过程,但是已知b,a,p求i以当前的计算机运算水平是无法完成的。所以通过这个公式就有了DH四次握手。

DH四次握手:

        首先客户端向服务器发送请求,请求进行DH连接,发送自己的TLS版本号,加密算法序列套件,以及第一个随机数给服务器。

        服务器接收到后,确认TLS版本号,选择何时的加密算法序列,以及生成第二个随机数,同时生成密钥a,以及随机两个数g和p,其中g是底数,p是用于取模的素数。然后将a作为指数g^a(mod p)计算出公钥A,并且申请CA认证后发送给客户端。发送的信息有:g,p,公钥A数字证书,TLS版本确定信息,第二个随机数,加密算法序列。

        客户端拿到CA证书后进行鉴别,鉴别成功后取出公钥A,拿出g和p,自己生成一个私钥b,用同样的算法计算出公钥B,然后通过A,g,p,b,第一个随机数,第二个随机数计算出最终密钥,向服务器发送CA认证的公钥B证书,请求切换为对称加密通信模式。

        计算方法:

        服务器拿到B证书后鉴别,通过的话取出B,结合g,p,a,第一个随机数,第二个随机数计算出相同的最终密钥。向客户端发送确认信息,此时对称加密通信开始。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Aristocrat l

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

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

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

打赏作者

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

抵扣说明:

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

余额充值