国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Node.js如何使用Diffie-Hellman密鑰交換算法詳解

2019-11-19 15:32:59
字體:
來源:轉載
供稿:網友

簡介

Diffie-Hellman(簡稱DH)是密鑰交換算法之一,它的作用是保證通信雙方在非安全的信道中安全地交換密鑰。目前DH最重要的應用場景之一,就是在HTTPS的握手階段,客戶端、服務端利用DH算法交換對稱密鑰。

下面會先簡單介紹DH的數理基礎,然后舉例說明如何在nodejs中使用DH相關的API。下面話不多說了,來一起看看詳細的介紹吧。

數論基礎

要理解DH算法,需要掌握一定的數論基礎。感興趣的可以進一步研究推導過程,或者直接記住下面結論,然后進入下一節。

  • 假設 Y = a^X mod p,已知X的情況下,很容易算出Y;已知道Y的情況下,很難算出X;
  • (a^Xa mod p)^Xb mod p = a^(Xa * Xb) mod p

握手步驟說明

假設客戶端、服務端挑選兩個素數a、p(都公開),然后

  • 客戶端:選擇自然數Xa,Ya = a^Xa mod p,并將Ya發送給服務端;
  • 服務端:選擇自然數Xb,Yb = a^Xb mod p,并將Yb發送給客戶端;
  • 客戶端:計算 Ka = Yb^Xa mod p
  • 服務端:計算 Kb = Ya^Xb mod p
Ka = Yb^Xa mod p= (a^Xb mod p)^Xa mod p = a^(Xb * Xa) mod p= (a^Xa mod p)^Xb mod p= Ya^Xb mod p= Kb

可以看到,盡管客戶端、服務端彼此不知道對方的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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 三都| 北流市| 汨罗市| 揭东县| 云浮市| 灵武市| 咸丰县| 道孚县| 客服| 旅游| 塔河县| 华坪县| 台安县| 红河县| 城市| 南江县| 建宁县| 茂名市| 三原县| 分宜县| 衡阳县| 喜德县| 万源市| 绵竹市| 美姑县| 襄城县| 安义县| 丹阳市| 宽城| 云安县| 陵川县| 小金县| 巴彦淖尔市| 钦州市| 延庆县| 偏关县| 宁明县| 永胜县| 漯河市| 鹤岗市| 同德县|