Diffie-Hellman算法

今天在学习node.js的crypto的时候看到了DH秘钥交换算法,于是从网上学习了下DH算法的原理,在此简单的记录下其实现。

数理基础:在了解DH算法之前我们来了解一下其基于数论部分的基础:(a^X mod p)^y mod p = a^(X*Y) mod p = (a^y mod p)^X mod p

DH算法在交换秘钥时发生的运算:

前提:在客户端和服务端约定一个素数p,一个有限域FP的生成阶a

步骤:

  1. Client端选择一个随机c,生成需发送至服务端的公钥 CP=a^c mod p;
  2. Server端选择一个随机数s,生成需发送至客户端的公钥SP=a^s mod p;
  3. 客户端计算秘钥:CR = SP^c mod p;
  4. 服务端计算秘钥:SR = CP^s mod p;

根据之前的公式可以的出:

CR = SP^c mod p=(a^s mod p)^c mod p=a^(s*c) mod p=(a^c mod p)^s mod p =CP^s mod p=SR;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值