时间:2021-05-26
简介
Diffie-Hellman(简称DH)是密钥交换算法之一,它的作用是保证通信双方在非安全的信道中安全地交换密钥。目前DH最重要的应用场景之一,就是在HTTPS的握手阶段,客户端、服务端利用DH算法交换对称密钥。
下面会先简单介绍DH的数理基础,然后举例说明如何在nodejs中使用DH相关的API。下面话不多说了,来一起看看详细的介绍吧。
数论基础
要理解DH算法,需要掌握一定的数论基础。感兴趣的可以进一步研究推导过程,或者直接记住下面结论,然后进入下一节。
握手步骤说明
假设客户端、服务端挑选两个素数a、p(都公开),然后
可以看到,尽管客户端、服务端彼此不知道对方的Xa、Xb,但算出了相等的secret。
Nodejs代码示例
结合前面小结的介绍来看下面代码,其中,要点之一就是client、server采用相同的素数a、p。
var crypto = require('crypto');var primeLength = 1024; // 素数p的长度var generator = 5; // 素数a// 创建客户端的DH实例var client = crypto.createDiffieHellman(primeLength, generator);// 产生公、私钥对,Ya = a^Xa mod pvar clientKey = client.generateKeys();// 创建服务端的DH实例,采用跟客户端相同的素数a、pvar server = crypto.createDiffieHellman(client.getPrime(), client.getGenerator());// 产生公、私钥对,Yb = a^Xb mod pvar serverKey = server.generateKeys();// 计算 Ka = Yb^Xa mod pvar clientSecret = client.computeSecret(server.getPublicKey());// 计算 Kb = Ya^Xb mod pvar serverSecret = server.computeSecret(client.getPublicKey());// 由于素数p是动态生成的,所以每次打印都不一样// 但是 clientSecret === serverSecretconsole.log(clientSecret.toString('hex'));console.log(serverSecret.toString('hex'));总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
相关链接
理解 Deffie-Hellman 密钥交换算法
迪菲-赫尔曼密钥交换
Secure messages in NodeJSusing ECDH
Keyless SSL: The Nitty Gritty Technical Details
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Linux使用Node.js建立访问静态网页的服务实例详解一、安装node.js运行所需要的环境,:二、创建node目录(/node/www),并在目录下创建n
Node.js内置的Crypto库,它提供各种加密算法,可以非常方便地让我们使用密码技术,解决应用开发中的问题。主要支持hash(哈希),hmac(密钥哈希),
Node.js是一个开源JavaScript运行时环境。在这里,您将学习如何在CentOS8服务器上安装Node.js。什么是Node.js?Node.js是一
非对称加密算法是相对于对称加密算法来说的,对于对称加密算法请查阅之前的总结,今天为大家介绍一下DH算法,DH是一种密钥交换算法,接收方根据发送方加密时的密钥,生
前言Node.js是JavaScript的一个解析器,可以运行js文件,今天就是简单说一下如何使用Node.js下的request模块下载文件。1、reques