DH密钥协商算法报告材料文档
dh交换算法
dh交换算法
DH交换算法,即Diffie-Hellman密钥交换算法,是一种确保共享密钥安全穿越不安全网络的方法,也被称为密钥一致协议。
该算法由公开密钥密码体制的奠基人Whitfield Diffie和Martin Hellman于1976年提出。
DH交换算法的主要思想是在公开媒体上交换信息,以生成一致的、可以共享的密钥。
DH交换算法的基本通信模型如下:
1. 甲方(Alice)将自己的公钥(G、GA)发送给乙方(Bob);
2. 乙方根据甲方发来的公钥,生成自己的公钥(GB)和私钥(Gab);
3. 乙方将自己的公钥(GB)发送给甲方;
4. 甲方和乙方根据彼此的公钥(G、GB)和预先约定的初始值(g、p),通过数学运算生成相同的本地密钥(Shared Key)。
DH交换算法的数学原理是基于椭圆曲线加密体制,通过计算两个随机数a和b的乘积mod p(modular exponentiation),得到一个共享密钥。
这里的p是一个大质数,G是椭圆曲线上的一个点,GA和GB 分别是甲方和乙方生成的公钥。
在实际应用中,DH交换算法通常与其他加密算法结合使用,如对称
加密算法。
在双方交换了本地密钥后,可以使用该密钥对数据进行加密和解密,确保数据传输的安全性。
总之,DH交换算法是一种在非安全通道中建立共享密钥的加密协议,通过数学运算确保了密钥的安全传输和生成。
它为网络通信提供了保密性和安全性,广泛应用于各种加密协议和网络安全场景。
dh公钥密码算法
DH公钥密码算法是一种基于数论的公钥密码算法,其基本思想是利用两个大素数相乘的积来生成一对公钥和私钥,从而实现加密和解密操作。
具体来说,DH算法包括以下几个步骤:
协商公共参数g和p:通信双方需要预先协商一个大素数p和一个生成元g,其中g是p的子集中的一个元素。
各自生成私钥:通信双方在1到p-1之间随机选择一个整数作为私钥,记作Xa和Xb。
计算公钥:通信双方根据公钥公式y=g^x mod p计算出各自的公钥,记作y1和y2。
交换公钥:通信双方将各自的公钥通过公开信道交换给对方。
计算共享密钥:通信双方根据共享密钥公式k=yb*xa mod p计算出共享密钥k1和k2。
通过以上步骤,通信双方可以生成一对公钥和私钥,并通过交换公钥来加密和解密消息。
由于只有通信双方拥有私钥,因此只有他们可以解密消息,而第三方无法解密。
同时,由于公钥是通过私钥计算得出的,因此第三方也无法通过公钥来计算出私钥,从而保证了通信的安全性。
DH算法原理
DH算法原理DH 是 Diffie-Hellman的首字母缩写,是Whitefield与Martin Hellman在1976年提出了一个的密钥交换协议。
我个人倾向于称DH算法为密钥协商协议而RSA算法是密钥交换算法。
本篇分为几个部分,第一个部分介绍一下密钥交换的场景;第二部分介绍一下DH算法的的步骤,以及由该算法引出的一些问题;第三部分开始讲数学原理。
数学原理可能涉及到数论、抽象代数,本篇尽量在每个公式后面证明该公式的正确性。
简单场景&简单的密钥协商先从一个应用场景说起:Alice 和Bob想要在一个不安全的信道共享一个密钥,该密钥可被用来进行后续的其他的操作,并且仅被Alice和Bob所知,第三方无法得知。
一个简单的方法就是,现在全世界都是知道一个值 P=100。
Alice生成随机值5,然后乘上P,接着发送Pa = 500给Bob;通样Bob生成随机值6,然后乘上P,接着发送Pb = 600给Alice。
这样,Alice 有 100,5 ,600,Bob有100,6,500。
Alice计算: 随机值5(自己私钥) * 600(对端的公钥) = 3000 等式1 Bob计算 : 随机值6(自己私钥) * 500(对端的公钥) = 3000 等式2这样 Alice就和Bob共享了一个值3000,还有谁知道3000这个值呢?我们知道Alice明文的将500发送到不安全信道,Bob明文的将600发送到不安全信道,这也就意味着第三方仅仅知道500 和600,想要计算获得共享密钥,第三方要么获取到Alice的随机值然后拿它乘上600,要么获取到Bob的随机值然后拿它乘上500,这样才能获取到Alice和Bob的共享密钥。
问题来了,如何获取到Alice的随机值呢?第三方知道,Alice发送的500是由P乘上Alice的随机值得到的,所以问题变成了求方程 x*100 = 500的解。
一眼就能看出来,Alice的随机值是5。
密钥协商机制范文
密钥协商机制范文密钥协商机制(Key Exchange Protocol)是指在网络通信中,双方通过其中一种协商方式确定一个共享的密钥,以便进行加密和解密操作,从而确保通信的安全性和机密性。
在计算机网络中,密钥协商机制是保证数据传输安全性的重要手段之一、本文将介绍几种常见的密钥协商机制及其原理。
1. 对称密钥协商机制(Symmetric Key Exchange)对称密钥协商机制是指在通信开始前,双方通过公共通道交换信息,从而得到共享的密钥。
常见的对称密钥协商机制包括Diffie-Hellman密钥交换协议、密钥加扰算法等。
其中,Diffie-Hellman密钥交换协议通过难求解离散对数问题的数学原理,实现了在公开信道上安全地交换密钥。
而密钥加扰算法则利用一些随机数和散列函数生成密钥,确保密钥的安全性。
2. 公钥密码学协商机制(Public Key Cryptography)公钥密码学协商机制是一种基于公钥密码学的密钥协商方式。
在这种机制中,通信双方各自生成一对密钥,即公钥和私钥。
公钥可以公开,而私钥则保密。
通信双方通过交换公钥,并使用对方的公钥对数据进行加密或签名,从而实现密钥协商。
常见的公钥密码学协商机制包括RSA、DSA、ECDH等。
值得注意的是,公钥密码学机制具有较高的计算开销,因此在实际应用中往往与对称密钥机制结合起来使用。
3. 基于身份的密钥协商机制(Identity Based Key Exchange)基于身份的密钥协商机制是一种新型的密钥协商方式,它可以消除传统公钥基础设施(PKI)中的证书管理问题。
这种机制通过将用户的身份直接映射到密钥上,从而实现了直接从用户的身份生成密钥的功能。
常见的基于身份的密钥协商机制包括基于椭圆曲线的身份密钥协商机制、基于身份的加密(IBE)等。
总结起来,密钥协商机制是通过其中一种方式在通信双方之间安全地交换密钥,以确保数据传输的机密性和安全性。
不同的密钥协商机制有不同的原理和特点,各有优势和适用场景。
基于dh密钥协商的组密钥管理方案
基于dh密钥协商的组密钥管理方案下载提示:该文档是本店铺精心编制而成的,希望大家下载后,能够帮助大家解决实际问题。
文档下载后可定制修改,请根据实际需要进行调整和使用,谢谢!本店铺为大家提供各种类型的实用资料,如教育随笔、日记赏析、句子摘抄、古诗大全、经典美文、话题作文、工作总结、词语解析、文案摘录、其他资料等等,想了解不同资料格式和写法,敬请关注!Download tips: This document is carefully compiled by this editor. I hope that after you download it, it can help you solve practical problems. The document can be customized and modified after downloading, please adjust and use it according to actual needs, thank you! In addition, this shop provides you with various types of practical materials, such as educational essays, diary appreciation, sentence excerpts, ancient poems, classic articles, topic composition, work summary, word parsing, copy excerpts, other materials and so on, want to know different data formats and writing methods, please pay attention!基于DH密钥协商的组密钥管理方案概述在现代网络通信中,确保数据安全性至关重要。
dh 密钥协商协议
dh 密钥协商协议DH(Diffie-Hellman)密钥协商协议是一种用于安全通信的协议,其目的是让通信双方在没有事先约定密钥的情况下协商一个共享的密钥。
DH协议的核心思想是利用离散对数的困难性质,从而实现安全的密钥交换。
DH协议的具体步骤如下:1. 首先,通信双方需要通过公开信道传输一些公共参数:a. 一个质数p,作为有限域的模数;b. 一个整数g,作为原根;2. Alice和Bob各自选择一个私密值,其中,Alice选择一个随机数a,Bob选择一个随机数b。
3. Alice和Bob利用公共参数计算出私密值的公开值:a. Alice计算A = g^a mod p;4. Alice和Bob之间通过公开信道交换各自的公开值A和B。
6. Bob同样计算共享密钥K' = A^b mod p。
7. 通过比较K和K’,确认两者是否相同。
如果相同,那么Alice和Bob就可以使用共享密钥进行加密通信。
DH协议的安全性基于离散对数问题的难度,即在有限域上寻找一个指数,使得给定的基数取这个指数的余数等于给定的数值。
这个问题目前是一个NP问题,并且很难找到可行的算法进行攻击。
虽然DH协议本身是安全的,但是由于存在中间人攻击可能,因此实际应用中常常会采用其他安全协议来保证通信的安全。
例如,在TLS协议中,可以使用DH协议来协商密钥,同时还通过数字证书来验证通信方的身份,以及使用对称加密算法来保证通信过程中的保密性和完整性。
总之,DH密钥协商协议是一种简单有效的密钥协商技术,它利用离散对数问题的难度保证了密钥交换过程的安全性。
然而在实际应用中需要注意中间人攻击等可能的安全威胁。
dh密钥协商算法
DH密钥协商算法1. 简介DH密钥协商算法(Diffie-Hellman Key Exchange Algorithm)是一种用于在公共网络上安全地协商共享密钥的密码学算法。
它在1976年由Whitfield Diffie和Martin Hellman提出,是公钥密码学的先驱之一。
DH密钥协商算法的设计目标是实现秘密通信,确保通信双方能够协商并共享一个只有他们两个人知道的密钥。
2. 原理DH密钥协商算法基于数论的一个基本问题,即“离散对数问题”。
该问题是指对于一个大素数p和一个整数a,已知a和p的幂(a^x mod p),求解x的值。
离散对数问题被认为是一个计算复杂度较高的问题,目前没有已知的快速算法可以有效地解决。
DH密钥协商算法的基本思想是,通信双方通过互相交换一些公开的信息来生成共享的密钥。
具体步骤如下:1.双方约定一个大素数p和一个生成元g,其中p是一个较大的随机素数,g是一个小于p的数。
2.双方各自选择一个私密的数,分别记为a和b。
3.通信双方分别计算公开值A和B,其中A = g^a mod p,B = g^b mod p。
4.双方交换公开值A和B。
5.通信双方分别计算共享密钥,A^b mod p 和 B^a mod p。
6.此时,双方得到的密钥是相同的,可以用于加密和解密通信内容。
3. 安全性DH密钥协商算法的安全性基于离散对数问题的困难性。
即使敌方知道了A、B和g 的值,也很难从中推导出双方的私密值a和b,进而猜测出共享密钥。
其安全性也取决于大素数p和生成元g的选择。
若p和g选取不当,可能会使算法易受到攻击。
因此,在实际应用中,需要选取足够大的素数p和合适的生成元g,以保证DH密钥协商算法的安全性。
另外,协商出的密钥并未被加密传输,为了保证通信的机密性,还需要使用对称密钥加密算法对通信内容进行加密。
4. 优势与应用DH密钥协商算法有以下优势和应用领域:•秘密性:通过DH密钥协商算法,通信双方可以在公共网络上协商出一个只有他们两个人知道的共享密钥,确保通信内容的机密性。
Diffie-Hellman算法简介
Diffie-Hellman算法简介
⼀、DH算法是⼀种密钥交换协议,它可以让双⽅在不泄漏密钥的情况下协商出⼀个密钥来。
DH算法基于数学原理,⽐如⼩明和⼩红想要协商⼀个密钥,可以这么做:
1. ⼩明先选⼀个素数和⼀个底数,例如,素数p=23,底数g=5(底数可以任选),再选择⼀个秘密整数a=6,计算A=(g^a mod p)=8,然后⼤声告诉⼩红:p=23,g=5,A=8;
2. ⼩红收到⼩明发来的p,g,A后,也选⼀个秘密整数b=15,然后计算B=(g^b mod p)=19,并⼤声告诉⼩明:B=19;
3. ⼩明⾃⼰计算出s=(B^a mod p)=2,⼩红也⾃⼰计算出s=(A^b mod p)=2,因此,最终协商的密钥s为2。
在这个过程中,密钥2并不是⼩明告诉⼩红的,也不是⼩红告诉⼩明的,⽽是双⽅协商计算出来的。
第三⽅只能知道p=23,g=5,A=8,B=19,由于不知道双⽅选的秘密整数a=6和b=15,因此⽆法计算出密钥2。
⼆、数学证明:
对于⼩明的密钥计算过程有:
s1 = (g^b mod p)^a mod p = g^(b*a) mod p
对于⼩红的密钥计算过程有::
s2 = (g^a mod p)^b mod p = g^(a*b) mod p
根据乘法交换律,s1 == s2
三、神奇的数学,完美的加密算法?
开始看到这个过程的时候,我着实⼩激动了⼀下,选择合适的素数,这个密钥的协商简直是”⽆懈可击“,怎么应⽤不怎么⼴泛呢?
查了⼀下资料,好吧,这个如果⽤于实战的话,⼀个”代理“就轻易的使这种加密完全⽆效。
所以现在⽤的⽐较⼴泛的加密算法是RSA(⾮对称加密算法)
参考⽂档:。
dh密钥交换算法
dh密钥交换算法DH密钥交换算法是一种常用的加密算法,它可以在允许第三方存在的情况下,使双方在不暴露密钥的情况下进行加密通信。
下面,我们来详细探讨DH密钥交换算法的工作原理与应用。
一、DH密钥交换算法的基本原理1.1 DH密钥交换算法的定义DH密钥交换算法是一种基于离散对数问题的密钥交换协议,它是由技术先驱D-H(Diffie-Hellman)在1976年提出的。
DH算法最基本的想法是:两个人通过公开的通道协商一个密钥,但是在这个过程中,他们不会直接传递密钥,而是在互相公开一个数的情况下,通过某些数学计算得出最终的密钥。
1.2 DH密钥交换算法的运作过程DH密钥交换算法的运作过程可以分为如下几个步骤:1. 甲方选择一个大素数p和一个原根g,并将它们公布给乙方;2. 甲方选择一个私钥a,并计算出A=g^a mod p,然后将A发送给乙方;3. 乙方选择一个私钥b,并计算出B=g^b mod p,然后将B发送给甲方;4. 甲方与乙方通过公式:(g^b mod p)^a mod p=(g^a mod p)^b mod p,得出共同的密钥K。
二、DH密钥交换算法的安全性分析2.1 DH密钥交换算法的优点DH密钥交换算法的优点主要有以下几点:1. 它不需要传递秘密密钥,因此比对称密钥加密算法更为安全;2. 在互相知晓的条件下,两个人可以生成相同的密钥而不会被窃听者截获;3. DH算法可以通过改变a和b的值来生成不同的密钥,因此针对同一个DH密钥交换协议进行攻击的难度较大。
2.2 DH密钥交换算法的缺点虽然DH密钥交换算法具有上述诸多优点,但在实际应用中,它仍然存在以下缺点:1. 由于DH算法本身没有数字签名的特性,因此无法保证对手方的合法性;2. DH算法也无法保证通信过程中数据的机密性和完整性。
三、DH密钥交换算法的应用DH密钥交换算法的应用非常广泛,常见的网络协议中就包含了DH算法的应用,如SSL、TLS、SSH、IPSec等。
DH密钥协商算法报告文档
DH密钥协商算法报告文档1.算法原理:DH密钥协商算法基于数论中的离散对数问题。
假设Alice和Bob想要协商一个对称加密密钥,他们可以选择一对大素数p和g作为公开参数。
Alice选择一个私密数a,并计算A=(g^a) mod p,并将A发送给Bob;Bob也选择一个私密数b,并计算B=(g^b) mod p,并将B发送给Alice。
然后Alice计算B^a mod p得到相同的密钥,Bob也计算A^b mod p得到相同的密钥。
这样,Alice和Bob就通过公共网络协商出了一个相同的密钥,用于后续的对称加密通信。
2.算法流程:(1)选择一个大素数p和一个原根g作为公开参数;(2)Alice选择一个私密数a,并计算A=(g^a) mod p,并将A发送给Bob;(3)Bob选择一个私密数b,并计算B=(g^b) mod p,并将B发送给Alice;(4)Alice计算B^a mod p得到相同的密钥;(5)Bob计算A^b mod p得到相同的密钥。
3.算法安全性:DH密钥协商算法的安全性基于数论中的离散对数问题,即找到一个整数x使得(g^x) mod p = A。
由于这个问题在计算上非常困难,所以攻击者很难通过已知的参数p、g和A推导出私密数a。
因此,DH密钥协商算法在理论上是安全的。
4.优势和限制:(1)算法强度高:DH密钥协商算法基于数论问题,攻击者很难通过已知的公开参数推导出私密数,保证了密钥的安全性。
(2)协商过程不需要传输密钥:DH密钥协商算法不需要将密钥通过网络传输,只需传输公开参数和计算结果,降低了泄露密钥的风险。
(3)算法可靠性有限:DH密钥协商算法依赖于公开参数的选择,在实际应用中需要确保公开参数的质量和安全性。
如果公开参数被攻击者篡改,可能导致密钥泄露或者协商出错误的密钥。
(4)中间人攻击风险:DH密钥协商算法本身没有提供身份验证和消息完整性保护机制,攻击者可能通过中间人攻击篡改或注入消息。
DH算法(密钥交换算法)
DH算法(密钥交换算法)⼀ 对称加密缺点密钥传递过程复杂,这是对称加密带来的困扰。
⼆ DH密钥交换算法特点构建本地密钥双⽅密钥⼀致三 DH相关参数四 DH算法实现过程1、初始化发送⽅的密钥(KeyPairGenerator、KeyPair、PublicKey)2、初始化接受⽅的密钥(KeyFactory、X509EncodedKeySpec、DHPublicKey、DHParameterSpec、KeyPairGenerator、PrivateKey)3、密钥构建(KeyAgeement、SecretKey、KeyFactory、X509EncodeKeySpec、PublicKey)4、加密和解密(Cipher)五 DH代码实现过程package com.imooc.security.dh;import java.security.KeyFactory;import java.security.KeyPair;import java.security.KeyPairGenerator;import java.security.PrivateKey;import java.security.PublicKey;import java.security.spec.X509EncodedKeySpec;import javax.crypto.Cipher;import javax.crypto.KeyAgreement;import javax.crypto.SecretKey;import javax.crypto.interfaces.DHPublicKey;import javax.crypto.spec.DHParameterSpec;import mons.codec.binary.Base64;//import .apache.xalan.internal.utils.Objects;public class ImoocDH {private static String src = "cakin24 security dh";public static void main(String[] args) {jdkDH();}public static void jdkDH() {try {//1.初始化发送⽅密钥KeyPairGenerator senderKeyPairGenerator = KeyPairGenerator.getInstance("DH");senderKeyPairGenerator.initialize(512);KeyPair senderKeyPair = senderKeyPairGenerator.generateKeyPair();byte[] senderPublicKeyEnc = senderKeyPair.getPublic().getEncoded();//发送⽅公钥,发送给接收⽅(⽹络、⽂件。
DH密钥协商算法报告文档
X X X X教院之阳早格格创做课程安排报告DH稀钥商谈算法课程称呼:暗号算法步调安排教死姓名:教死教号:博业班级:任课西席:2014年12 月 1日目录1. 选题背景稀钥商谈本量上是一个协议,它通过二个大概多个成员正在一个公启的疑道上通疑共同天修坐一个秘稀稀钥,普遍情况下,一个稀钥商谈规划的稀钥是某个函数的值,其输进量由通疑单圆提供,商谈历程是由一系列的程序步调完毕的.会话稀钥由每个协议介进者分别爆收的参数通过一定的估计得出.罕睹的稀钥商谈协议,如IKE.稀钥商谈协议的死成办法则可分为证书籍型战无证书籍型.证书籍型是指正在会话稀钥的爆收历程中,由一个可疑的证书籍核心(CA)给介进稀钥商谈的各圆各集收一个证书籍,此证书籍中含有此圆的,ID及其余疑息.证书籍型稀钥商谈协议的便宜是提招供证,姑且PKI(公钥暗号机造)广大安置,比较老练,应用里广,且由PKG管造公公钥对付有好处统一管造,缺面是估计代价大,需要一个可疑的CA,共时证书籍还需要维护.无证书籍型是指各圆正在举止会话稀钥的商谈历程中不需要证书籍的介进,那是姑且稀钥商谈协议的合流种类,便宜是不需要CA的介进,缩小了估计量,越收是正在矮耗环境下应用的更多,共时仄安性也不比证书籍型强.险些不明隐的缺面,不过安排一个仄安的越收矮耗的无证书籍稀钥商谈规划不是很简单.现有的流通的稀钥商谈协议,皆使用了Diffie-Hellman,它们基础上不妨瞅成是Diffie-Hellman的扩展.也便是道,群组稀钥商谈协议不妨明白成怎么样使用Diffie-Hellman去真止群的稀钥接换.2. DH稀钥商谈算法2.1 算法的爆收Diffie-Hellman稀钥接换协议是第一个被提出的稀钥商谈规划,是好国斯坦祸大教的W.Diffie战M.E.Hellman于1976年提出的,它是第一个刊登的公钥暗号机造,Diffie-Hellman算法的唯一手段便是使二个用户能仄安的接换稀钥,进而得到一个共享的会话稀钥(秘稀稀钥).需要注意的是,该算法自己不克不迭用于加稀解稀,只可用于稀钥的接换,单圆决定要用的稀钥后,要使用其余对付称稀钥支配加稀算法本量加稀妥协稀消息.2.2 算法的形貌1. 失集对付数的观念:1)本根:如果a是素数p的一个本根,那么数值:a mod p,a^2 mod p,…,a^(p-1) mod p是各不相共的整数,且以某种排列办法组成了从1 到p-1 的所有整数.2)失集对付数:如果对付于一个整数b战素数p的一个本根a,不妨找到一个唯一的指数i,使得b =(a^i)modp,其中0≦i≦p-1,那么指数i称为b的以a为基数的模p的失集对付数.2. 算法灵验性Diffie-Hellman 算法的灵验性依好于估计失集对付数的易度,其含意是:当已知大素数p战它的一个本根a后,对付给定的b,要估计i ,被认为是很艰易的,而给定i 估计b 却相对付简单.3. Diffie-Hellman算法:假若用户A战用户B期视接换一个稀钥.与素数p战整数a,a是p的一个本根,公启a战p.1)A采用大的随机数RA(0<=RA<=p-2),并估计SA=(a^RA) mod p,而且把SA收收给用户B.2)B采用随机数RB(0<=RB<=p-2),并估计SB=(a^RB) mod p,而且把SB收收给用户A.3)A估计稀钥的办法是:K=(SB) ^RA mod p,B估计稀钥的办法是:K=(SA) ^RB mod p,道明:(SB)^ RA mod p = (a^RB mod p)^ RA mod p= (a^RB)^ RA mod p= (a^RA) ^RBmod p(-- 稀钥即为 a^(RA*RB) mod p)=(a^RA mod p)^ RB mod p= (SA) ^RB mod p由于RA战RB是窃稀的,而第三圆惟有p、a、SB、SA不妨利用,惟有通过与失集对付数去决定稀钥,然而对付于大的素数p,估计失集对付数是格外艰易的.4. 例子:假若用户Alice战用户Bob期视接换一个稀钥,与一个素数p =97战97的一个本根a =5,Alice战Bob分别采用秘稀稀钥RA=36战RB=58 ,并估计各自的公启稀钥:SA=a^RA mod p =5^36 mod 97=50SB=a^RB mod p =5^58 mod 97=44Alice战Bob接换了公启稀钥之后,估计共享稀钥如下:Alice:K=(SB) ^RA mod p=44^36 mod 97=75Bob:K=(SA) ^RB mod p=50^58 mod 97=75Diffie-Hellman稀钥接换协议的基础模式如图2-1所示:3. DH稀钥商谈算法的真止3.1 安排央供功能央供(1)爆收一个偶数p ,推断是可是素数.素数央供介于2^14-2^15.先用小于20的素数去试除,再使用Miller-Rabin概率检测算法举止检测;(2)供得模p 的一个本根,央供本根的值介于32-1024之间;(3)输出单圆采用的随机数,随机数介于2^5-2^7,使用模沉复仄要领举止估计,输出单圆的估计截止;(4)搜集传输圆里,不妨是C/S模式,也不妨是B/S模式;(5)输出末尾商谈的稀钥;3.1.2 输出央供(1)输出偶数的爆收历程,用函数真止爆收谦脚央供的偶数;(2)输出用小素数试除的推断历程,并输出屡屡试除之后的余数,用函数真止一次试除并返回试除之后的余数;(3)Miller-Rabin概率检测算法运止5次,输出检测历程及截止.用函数真止一次Miller-Rabin概率检测算法并返回检测截止;(4)如果不是偶素数,输出下一个偶数爆收的准则;(5)输出爆收模的一个本根的历程;(6)输出使用模沉复仄要领举止估计的历程战截止.3.2 模块区分及真止3.2.1 小素数试除算法形貌:小素数试除主假若用随机爆收的数去试除小于20的素数,以此简朴判决该随机数是可是素数.真止办法:以本次步调编写为例,与小素数数组S_PrimeTable[7] = { 3, 5, 7, 11, 13, 17, 19 },用爆收的大随机数去除以数组中的元素,若所得余数不为0,则能姑且推断该随机数为素数.简曲真止代码如下:int SPrime(int odd){int i, remainder, k = 0;for (i = 0; i<7; i++){remainder = odd % S_PrimeTable[i];printf("第%d次小素数%d试除的余数为%d.\n", i + 1, S_PrimeTable[i], remainder);if (remainder == 0)k++;}if(!k){printf("小素数试除推断%d是素数.\n\n",odd);}else{printf("小素数试除推断%d不是素数.\n\n",odd);}return !k;}3.2.2 模沉复仄要领算法形貌:模沉复仄要领是对付大整数模m战大整数e估计b^e(mod m).正在本次安排中,模沉复仄要领主要使用正在米勒检测算余值部分、供本根部分、SA战SB的估计以及末尾稀钥的估计历程中,其中,SA战SB的估计以及末尾稀钥的估计央供输出估计历程.(为了界里隐现好瞅,正在此写了二个模沉复仄圆算法的代码,思路相共,不过正在其中一个函数中写了输出估计历程,该函数用去估计SA战SB以及末尾的稀钥.)真止办法:令a=1,并将十进造数e写成二进造,若二进造数值为1,则估计a≡(a*b)mod n,b≡(b*b)mod n;若二进造数值为0,则估计a≡a mod n,b ≡(b*b)mod n.末尾a即为最后估计截止.简曲真止代码如下:int MoChongFu(int m, int e,int n){int binary[22];int count=0,i;int a=1,b;b=m;do{binary[count]=e%2;e=e/2;count++;}while(e!=0);for(i=0;i<count;i++){if(binary[i]==1){a=(a*b)%n;b=(b*b)%n;//printf("a=%d, b=%d\n",a,b);}if(binary[i]==0){a=a;b=(b*b)%n;//printf("a=%d, b=%d\n",a,b);}}return a;}Miller-Rabin检测算法算法形貌:米勒检测正在本次安排中主要用去检测正在小素数判决了之后的随机数是可是素数.真止办法:将待检测的数n写成n-1=2s*t,采用随机数a,估计b≡atmod n.若b mod n≡1,则n是素数.可则,干如下循环,循环次数为1—s:如果bmod n≡-1,则b是素数,可则,b≡b*b mod n.简曲真止代码如下:int milejiance(int odd){int s=0,i,count=0;int a,b,t,num;num=odd-1;while(1){if(num%2==0){s++;num=num/2;}else{t=num;break;}}printf("将%d写成%d-1=2^%d*%d\t\t\n",odd,odd,s,t);a=rand()%(odd-3)+2;printf("爆收的随机数a是:%d\n",a);b=MoChongFu(a,t,odd);printf("第1次算出的余值是:%d\n",b);if(b%odd==1||b==(odd-1))return 1;for(i=0;i<s;i++){b=(b*b)%odd;printf("第%d次算出的余值为%d \n",i+2,b);if(b==(odd-1)){return 1;}}return 0;}本根的爆收算法形貌:央供一个素数一定范畴内的本根,该当先供该素数的最小本根.根据定理:设m>1,m的欧推函数a所有分歧素果数是q1,q2,…,qk,则g是模m的一个本根的充要条件是 g^(a/qi)!=1(mod m),i=1,2,…k 真止办法:先供大素数的欧推函数的素果数a[n],并通过素果数供得g 的指数c[n],接着考证g^c[n] 是可共余于1,对付g=2,3…,逐个验算,曲到算出最小的g值谦脚g^c[n]均分歧余于1,那么g即是大素数m的最小本根,果为当c[n]遍历欧推函数a的简化结余系时,g^c[n]遍历模m的所有本根,所以不妨通过欧推函数的简化结余系供得谦脚央供的本根.简曲真止代码如下:int yuangen(int yy){int n=2,g=0,q,k,j=0,a[10];int i=0,l=0;int gg;int c[10];int count=0,flag=0;q=yy-1;while(1){if (q%n==0){a[j]=n;j++;q=q/n;}n++;if(q<n)break;}printf("模%d的欧推函数领会量果数为:\n",yy);for(n=0;n<j;++n)printf("%d ",a[n]);printf("\n\n");printf("所以指数为:");for(n=0;n<j;++n){c[n]=(yy-1)/a[n];printf("%d ",c[n]);}printf("\n\n");for(g=2;;g++){for(n=0;n<j;++n){if(MoChongFu(g,c[n],yy)==1){printf("%d^%d=%d mod %d\n",g,c[n],MoChongFu(g,c[n],yy),yy);goto cd;}else{printf("%d^%d=%d mod %d\n",g,c[n],MoChongFu(g,c[n],yy),yy);}}gg=g;printf("所以%d是最小本根.\n",gg);goto ab;cd: ;}ab:for(g=3;;g++){if((yy-1)%g!=0){k=MoChongFu(gg,g,yy);if(k>32&&k<1024){printf("与介于2^5到2^10之间的一个本根值为:");printf("%d\n\n",k);return k;}}}return 0;}3.2.5 爆收随机素数算法形貌:使用srand()战rand()函数爆收随机数n,而后通过推断n%2是可为0去推断爆收的是可是偶数.简曲真止代码如下:int S_PrimeTable[7] = { 3, 5, 7, 11, 13, 17, 19 };//爆收一个随机数int Random_Odd(){int odd = 0;while (1){srand(time(NULL));odd = rand() % (16385) + 16384;if (odd % 2 != 0)break;}//printf("%d\n", odd);return odd;}4. 尝试报告⑴爆收偶素数,用小素数试除而且输出试除的余数,再举止Miller-Rabin 检测,若Miller-Rabin检测不通过,则输出爆收下一个随机数的准则并继承爆收下一个随机数,曲至爆收谦脚条件的偶素数,如图4-1、4-2所示:图 4-1 爆收随机数并用小素数试除图 4-2 米勒检测历程⑵代码调试的最后截止如图4-3、图4-4、图4-5、图4-6、图4-7、图4-8所示:图4-3 爆收随机数并用小素数试除图4-4 米勒检测历程图4-5 大素数的欧推函数领会量果数图4-6 供本根并估计各自的稀钥图4-7 模沉复仄要领估计历程图4-8 估计共共稀钥论断本文是正在教习了相闭C谈话知识、暗号教及相闭疑息仄安数教知识之上举止的安排,本安排采与C谈话真止,真止了DH稀钥商谈算法,用户A战用户B通过自己采用的随机数战公启的大素数通过失集对付数的某些算法供得稀钥,并相互接换稀钥,通过接换得去的稀钥爆收共共的稀钥.由于教死火仄有限,正在步调可读性战典型性上有着一定的短缺,略隐缺累,而正在真止功能上也隐得不是很完备,需要正在进一步的教习中得到提下.正在编写步调的历程中逢到了一些不可预防的过失战问题,然而是皆通过书籍本以及共教的助闲得以即时将那些问题办理,此次安排对付我的逻辑性明白战编程本领皆有一定的普及.参照文件[1] 谭浩强. C步调安排[M].北京:浑华大教出版,1999.12附源代码#include<stdio.h>#include<time.h>#include<math.h>#include<stdlib.h>int Random_Odd();int SPrime(int odd);int MoChongFu(int m, int e,int n);int MoChongFua(int m, int e,int n);int milejiance(int odd);int yuangen(int yy);int S_PrimeTable[7] = { 3, 5, 7, 11, 13, 17, 19 };int main(void){int yy=0;int gg;int A,B,Key,Key1,Key2;int SA,SB;int i,flag1,flag2;do{q:printf("**********************\n\n\n");while(yy == Random_Odd());yy = Random_Odd();printf("爆收的随机数是:%d\n\n",yy);flag1=!SPrime(yy);for(i=0;i<5;i++){flag2=!milejiance(yy);if(flag2){printf("第%d次米勒检测已通过.\n\n",i+1);printf("果为第%d次米勒检测不通过,所以随机数%d不是素数,\n爆收下一个随机数,先用小素数试除,再举止5次米勒检测,如果小素数试除通过而且5次皆通过,则道明该随机数是大素数.",i+1,yy);printf("\n");goto q;elseprintf("第%d次米勒检测通过.\n\n",i+1);}}while(flag1||flag2);gg=yuangen(yy);srand(time(NULL));A = rand()%(96)+32;B = rand()%(96)+32;printf("Alice采用的随机数A是:%d\n",A);printf("Bob采用的随机数B是:%d\n\n",B);printf("估计SA=(gg^A) mod yy:\n");SA=MoChongFua(gg,A,yy);printf("\n");printf("估计SB=(gg^B) mod yy:\n");SB=MoChongFua(gg,B,yy);printf("所以SA战SB分别是:%d,%d\n\n",SA,SB); printf("估计Key1=(SB^A) mod yy:\n");Key1=MoChongFua(SB,A,yy);printf("\n");printf("估计Key2=(SA^B) mod yy:\n");Key2=MoChongFua(SA,B,yy);printf("所以:Key1=%d,Key2=%d\n\n",Key1,Key2); if(Key1==Key2)Key=Key1;printf("所以共共稀钥Key是:%d\n\n",Key); return 0;}//爆收一个随机数int Random_Odd(){int odd = 0;while (1)srand(time(NULL));odd = rand() % (16384) + 16384;if (odd % 2 != 0)break;}//printf("%d\n", odd);return odd;}//如果是素数的话返回1int SPrime(int odd){int i, r, k = 0;for (i = 0; i<7; i++){r = odd % S_PrimeTable[i];printf("第%d次小素数%d试除的余数为%d.\n", i + 1, S_PrimeTable[i], r); if (r == 0)k++;}if(!k){printf("小素数试除推断%d是素数.\n\n",odd);}else{printf("小素数试除推断%d不是素数.\n\n",odd);}return !k;}int MoChongFu(int m, int e,int n){int binary[22];int count=0,i;int a=1,b;b=m;do{binary[count]=e%2;e=e/2;count++;}while(e!=0);for(i=0;i<count;i++){if(binary[i]==1){a=(a*b)%n;b=(b*b)%n;}if(binary[i]==0){a=a;b=(b*b)%n;}}return a;}int MoChongFua(int m, int e,int n) {int binary[22];int count=0,i;int a=1,b;b=m;do{binary[count]=e%2;e=e/2;count++;}while(e!=0);for(i=0;i<count;i++)if(binary[i]==1){a=(a*b)%n;b=(b*b)%n;printf("a=%d, b=%d\n",a,b); }if(binary[i]==0){a=a;b=(b*b)%n;printf("a=%d, b=%d\n",a,b); }}return a;}//米勒检测int milejiance(int odd){int s=0,i,count=0;int a,b,t,num;num=odd-1;while(1){if(num%2==0){s++;num=num/2;}else{t=num;break;}printf("将%d写成%d-1=2^%d*%d\t\t\n",odd,odd,s,t); a=rand()%(odd-3)+2;printf("爆收的随机数a是:%d\n",a);b=MoChongFu(a,t,odd);printf("第1次算出的余值是:%d\n",b);if(b%odd==1||b==(odd-1)){return 1;}for(i=0;i<s-1;i++){b=(b*b)%odd;printf("第%d次算出的余值为%d \n",i+2,b);if(b==(odd-1)){return 1;}}return 0;}//欧推函数的素果数战二者的商int yuangen(int yy){int n=2,g=0,q,k,j=0,a[10];int gg;int c[10];q=yy-1;while(1){if (q%n==0){a[j]=n;j++;while()q=q/n;}while(!(q%n)){q=q/n;}if(q<n)break;}printf("模%d的欧推函数领会量果数为:\n",yy); for(n=0;n<j;++n)printf("%d ",a[n]);printf("\n\n");printf("所以指数为:");for(n=0;n<j;++n){c[n]=(yy-1)/a[n];printf("%d ",c[n]);}printf("\n\n");for(g=2;;g++){for(n=0;n<j;++n)。
分析DH加密算法,一种适基于密钥一致协议的加密算法。
分析DH加密算法,⼀种适基于密钥⼀致协议的加密算法。
DHDiffie-Hellman算法(D-H算法),密钥⼀致协议。
是由公开密钥密码体制的奠基⼈Diffie和Hellman所提出的⼀种思想。
简单的说就是允许两名⽤户在公开媒体上交换信息以⽣成"⼀致"的、可以共享的密钥。
换句话说,就是由甲⽅产出⼀对密钥(公钥、私钥),⼄⽅依照甲⽅公钥产⽣⼄⽅密钥对(公钥、私钥)。
以此为基线,作为数据传输保密基础,同时双⽅使⽤同⼀种对称加密算法构建本地密钥(SecretKey)对数据加密。
这样,在互通了本地密钥(SecretKey)算法后,甲⼄双⽅公开⾃⼰的公钥,使⽤对⽅的公钥和刚才产⽣的私钥加密数据,同时可以使⽤对⽅的公钥和⾃⼰的私钥对数据解密。
不单单是甲⼄双⽅两⽅,可以扩展为多⽅共享数据通讯,这样就完成了⽹络交互数据的安全通讯!该算法源于中国的同余定理——中国馀数定理。
流程分析:1.甲⽅构建密钥对⼉,将公钥公布给⼄⽅,将私钥保留;双⽅约定数据加密算法;⼄⽅通过甲⽅公钥构建密钥对⼉,将公钥公布给甲⽅,将私钥保留。
2.甲⽅使⽤私钥、⼄⽅公钥、约定数据加密算法构建本地密钥,然后通过本地密钥加密数据,发送给⼄⽅加密后的数据;⼄⽅使⽤私钥、甲⽅公钥、约定数据加密算法构建本地密钥,然后通过本地密钥对数据解密。
3.⼄⽅使⽤私钥、甲⽅公钥、约定数据加密算法构建本地密钥,然后通过本地密钥加密数据,发送给甲⽅加密后的数据;甲⽅使⽤私钥、⼄⽅公钥、约定数据加密算法构建本地密钥,然后通过本地密钥对数据解密。
1.2.通过java代码实现如下:Coder类见Java代码1. import java.security.Key;2. import java.security.KeyFactory;3. import java.security.KeyPair;4. import java.security.KeyPairGenerator;5. import java.security.PublicKey;6. import java.security.spec.PKCS8EncodedKeySpec;7. import java.security.spec.X509EncodedKeySpec;8. import java.util.HashMap;9. import java.util.Map;10.11. import javax.crypto.Cipher;12. import javax.crypto.KeyAgreement;13. import javax.crypto.SecretKey;14. import javax.crypto.interfaces.DHPrivateKey;15. import javax.crypto.interfaces.DHPublicKey;16. import javax.crypto.spec.DHParameterSpec;17.18. /**19. * DH安全编码组件20. *21. * @author 梁栋22. * @version 1.023. * @since 1.024. */25. public abstract class DHCoder extends Coder {26. public static final String ALGORITHM = "DH";27.28. /**29. * 默认密钥字节数30. *31. * <pre>32. * DH33. * Default Keysize 102434. * Keysize must be a multiple of 64, ranging from 512 to 1024 (inclusive).35. * </pre>36. */37. private static final int KEY_SIZE = 1024;38.39. /**40. * DH加密下需要⼀种对称加密算法对数据加密,这⾥我们使⽤DES,也可以使⽤其他对称加密算法。
DH密钥交换算法
DH算法
例1: 按照参数的选区原则, p 取一个素数, a 是 p 的一个原根,取 (a, p) = (3, 7) (1)Alice 选择一个范围在[1, p-1]的随机数,为Xa= 5 (2)Alice 计算Ya = a^Xa mod p = 3^5 mod 7 = 5 (3)Bob选择一个范围在[1, p-1]的随机数,为Xb = 6 (4)Bob计算Yb = a^Xb mod p = 3^6 mod 7 = 1
定理: 设 p > 1,gcd(a,p) = 1,则a^0, a^1, a^2, ... a^ord(a)-1 模p两两不同余。 证明:反证法
定 理 证 明
如若存在K,L(0<=L<K<ord(a)) 使得 a^K ≡ a^L mod p 则a^K = a^L + xp (x为整数) 又gcd (a , p)=1,即存在a^L的逆a^-L,
思考: 为什么DH算法 p需要是素数? a要是p的原根?
ECDH
ECC 算法和 DH结合使用,用于密钥磋商,这个密钥交换算法称为 ECDH 。交换双 方可以在不共享任何秘密的情况下协商出一个密钥。ECC是建立在基于椭圆曲线的 离散对数问题上的密码体制,给定椭圆曲线上的一个点P,一个整数k,求解Q=kP 很容易;给定一个点P、Q,知道Q=kP,求整数k确是一个难题。ECDH即建立在 此数学难题之上。
,则a称作为模p的原根。
定理: 设 p > 1,gcd(a,p) = 1,则a^0, a^1, a^2, ... a^ord(a)-1 模p两两不同余。
gcd(a, p) = 1,a与p互质,互质的数必须是自然数,所以a从1开始取。 例:取p=7,a=1,2,3… a=1 1^1mod 7=1 a=2 2^1mod 7=2 2^2mod 7=4 2^3mod 7=1 a=3 3^1mod 7=3 3^2mod 7=2 3^3mod 7=6 3^4mod 7=4 3^5mod 7=5 3^6mod 7=1 阶:1
DH密钥协商算法报告文档
DH密钥协商算法报告文档一、DH密钥协商算法的原理1.选择一个大质数p和一个原根g。
2. 甲方选择一个私密数a,并计算A = g^a mod p,将A发送给乙方。
3. 乙方选择一个私密数b,并计算B = g^b mod p,将B发送给甲方。
4. 甲方利用收到的B和自己的私密数a计算出密钥S = B^a mod p。
5. 乙方利用收到的A和自己的私密数b计算出密钥S = A^b mod p。
6.甲方和乙方生成的密钥S相同,可以用于后续的对称加密通信。
二、DH密钥协商算法的优点1.安全性高:DH密钥协商算法基于离散对数的计算困难性,即使在不安全的通信渠道上,也能确保双方只能生成相同的密钥,而无法通过截获和分析数据推算出密钥。
2.密钥长度可变:DH密钥协商算法可以选择不同的质数p和原根g,通过调整参数的大小,可以生成不同长度的密钥,以适应不同安全需求。
3.公开参数交换:DH密钥协商算法只需要交换公开参数A和B,而不需要交换私密数,减少了通信量和计算量。
三、DH密钥协商算法的应用场景1. VPN(Virtual Private Network):DH密钥协商算法可用于在远程访问VPN时,协商双方之间的对称加密密钥,保证通信的机密性。
2.SSL/TLS通信:DH密钥协商算法可用于HTTPS的握手过程,通过生成相同的密钥,实现客户端和服务器之间的通信机密性。
3.移动通信:DH密钥协商算法可用于移动通信网络中的鉴权和密钥协商过程,保护用户的隐私和通信数据的安全。
四、DH密钥协商算法的安全性分析DH密钥协商算法的安全性基于离散对数问题的困难性,即找到满足条件g^x ≡ y (mod p)的x的困难性。
该问题尚未被证实为NP难问题,但通过选择足够大的质数p和合适的原根g,可以使算法在实际应用中具有足够的安全性。
然而,DH密钥协商算法也存在一些安全性弱点,例如:1.中间人攻击:DH密钥协商算法并不能防止中间人攻击,即有可能在通信过程中插入伪造的公开参数,从而导致生成的密钥被中间人截获。
密钥协商算法
密钥协商算法近年来,随着信息系统在各行各业的广泛应用,安全性已经成为一个重要的关注点。
在信息的传输过程中,密钥的安全是确保信息通信安全的重要因素,而密钥协商算法是用于传输方之间形成安全会话的重要工具。
密钥协商算法是一种用于实现完全安全通信的加密算法,允许信息发送者和接收者使用一个共享的密钥来加密信息。
它也允许用户之间的密钥交换,以便双方都能够使用同一个密钥。
这种算法的实现需要考虑到两个关键因素:首先是安全性,即使攻击者有能力监听通信,也不能破解通信的密钥;其次是可实施性,即必须能够实现自动化的过程。
常见的密钥协商算法包括DH (Diffie-Hellman)ECDH (Elliptic Curve Diffie-Hellman) 两种。
DH算法基于离散对数问题,旨在解决在未知环境中两个参与方之间交换私钥的问题。
ECDH算法是基于椭圆曲线密码学的密钥交换协议,用于在公开网络上传输困难破解的密钥。
在DH算法中,每个参与方都分别生成一个私钥和一个公钥,然后将自己的公钥分别发送给其他参与方。
每个参与方都使用对方的公钥和自己的私钥生成一个密钥,这就是所谓的“共享密钥”。
每个方都利用自己的私钥和对方的公钥生成的共享密钥进行加密,从而确保安全的通信。
ECDH算法允许参与方计算出一个共享椭圆曲线值,用于同步加密和解密的过程。
当公钥交换发生时,参与方会在共享密钥空间中随机生成私钥,并根据椭圆曲线加密算法计算出一个共享椭圆曲线值。
参与方之间进行椭圆曲线加密的过程也会根据共享椭圆曲线值产生相等的密钥。
在实际应用中,可以设计不同的系统结构来实现密钥协商算法,包括基于对等协议、维基协议和中心化协议。
对等协议是大家公认的比较安全的协议,其基本原理是不需要任何第三方服务器就可以实现双方之间的密钥协商。
维基协议则是一种基于双方共享一个秘钥的协议,它能够增强双方之间的安全性,但是它仍然需要一个可信任的第三方来处理双方之间的密钥协商。
DH算法原理范文
DH算法原理范文DH算法(Diffie-Hellman算法)是一种常用的密钥交换算法,被广泛应用于网络通信中。
DH算法的原理是基于数论的离散对数问题。
DH算法的主要目的是实现在不安全的通信通道上安全地交换密钥,以保证通信数据的机密性。
其原理可以简述为以下几个步骤:1.双方协商参数:选择两个大素数p和g,其中p为公开参数,为了保证安全性,p的位数一般要足够大;g为共享的底数,一般取较小的素数。
2.生成私钥:每个参与者生成一个私钥,私钥为一个小于p的随机数。
3. 计算公钥:参与者利用生成的私钥和公开参数计算公钥。
具体计算公式为公钥=(g^私钥)mod p。
4.交换公钥:参与者将生成的公钥发送给对方,对方也将自己的公钥发送给参与者。
5. 计算共享密钥:参与者利用对方发送的公钥和自己的私钥计算共享密钥。
具体计算公式为共享密钥=(对方公钥^私钥)mod p。
6.加密通信:参与者利用共享密钥对通信数据进行加密,确保数据的机密性。
7.解密通信:参与者利用共享密钥对加密数据进行解密,还原原始数据。
通过DH算法,双方可以在不事先共享密钥的情况下,通过公开的参数进行密钥交换。
这样,在通信过程中,即使窃听者获取到了参与者之间传递的公开参数和公钥,也无法计算出真正的私钥和共享密钥,从而保证了通信数据的机密性。
此外,由于DH算法基于离散对数问题,即使在计算资源足够的情况下,计算离散对数也是非常困难的,因此DH算法具备一定的安全性。
需要注意的是,DH算法仅用于密钥交换,而非加密算法。
在实际应用中,通常会结合其他的加密算法使用,例如使用共享的DH密钥对称加密算法(如AES)进行通信数据的加密。
总结来说,DH算法通过数论的离散对数问题实现了安全地密钥交换。
它的安全性在于即使窃听者获取了公开参数和公钥,也难以计算出私钥和共享密钥,从而保证通信数据的机密性。
在网络通信中,DH算法被广泛应用于密钥交换的场景,以确保通信数据的安全性。
dh参数计算
dh参数计算
在计算机网络领域中,DH(Diffie-Hellman)参数计算是一项重要的技术,用于安全地交换密钥。
DH参数计算的过程是如何进行的呢?我们来简单了解一下。
DH参数计算的核心在于两个人(通常是客户端和服务器端)如何协商一个共
享的密钥,而不被其他人截获。
为了实现这一目的,首先需要选择两个大素数p和g,其中p是一个很大的质数,g是一个原根模p的数。
这两个参数是公开的,可
以被所有人知晓。
在DH参数计算中,客户端和服务器端各自生成一个私钥,并根据公开的p和
g计算出对应的公钥。
然后,他们将各自的公钥发送给对方。
接收到对方的公钥后,客户端和服务器端再根据自己的私钥和对方的公钥计算出一个共享的密钥。
这个共享的密钥只有客户端和服务器端知晓,其他人无法获知。
DH参数计算的过程中,虽然公钥是公开的,但通过私钥和对方的公钥计算出
的共享密钥是保密的。
这样就实现了安全地交换密钥的目的。
在实际应用中,DH参数计算常常被用于SSL/TLS协议中,用于建立安全的通
信连接。
通过DH参数计算,客户端和服务器端可以在不安全的网络中安全地交换
密钥,保障通信的机密性和完整性。
总的来说,DH参数计算是一项重要的技术,可以帮助我们在网络通信中实现
安全的密钥交换。
通过了解DH参数计算的原理和过程,我们可以更好地理解网络
安全的重要性,以及如何保护通信的安全性。
愿我们在网络世界中,能够更加安全地进行信息交流和传输。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
X X X X学院课程设计报告DH密钥协商算法课程名称:密码算法程序设计学生姓名:学生学号:专业班级:任课教师:2014年12 月 1日目录1. 选题背景 (1)2. DH密钥协商算法 (1)2.1 算法的产生 (1)2.2 算法的描述 (2)2.3 算法的安全性 (3)3.DH密钥协商算法的实现 (4)3.1 设计要求 (4)3.1.1 功能要求 (4)3.2 模块划分及实现 (5)3.2.1 小素数试除 (5)3.2.2 模重复平方法 (5)3.2.3 Miller-Rabin检测算法 (6)3.2.4 原根的产生 (8)3.2.5 产生随机素数 (10)4.测试报告 (11)结论 (16)参考文献 (16)附源代码 (17)1. 选题背景密钥协商实际上是一个协议,它通过两个或多个成员在一个公开的信道上通信联合地建立一个秘密密钥,一般情况下,一个密钥协商方案的密钥是某个函数的值,其输入量由通信双方提供,协商过程是由一系列的顺序步骤完成的。
会话密钥由每个协议参与者分别产生的参数通过一定的计算得出。
常见的密钥协商协议,如IKE。
密钥协商协议的生成方式则可分为证书型和无证书型。
证书型是指在会话密钥的产生过程中,由一个可信的证书中心(CA)给参与密钥协商的各方各分发一个证书,此证书中含有此方的公钥,ID及其他信息。
证书型密钥协商协议的优点是提供认证,目前PKI(公钥密码体制)广泛部署,比较成熟,应用面广,且由PKG管理公私钥对有利于统一管理,缺点是计算代价大,需要一个可信的CA,同时证书还需要维护。
无证书型是指各方在进行会话密钥的协商过程中不需要证书的参与,这是目前密钥协商协议的主流种类,优点是不需要CA的参与,减少了计算量,尤其是在低耗环境下应用的更多,同时安全性也不比证书型弱。
几乎没有明显的缺点,只是设计一个安全的更加低耗的无证书密钥协商方案不是很容易。
现有的流行的密钥协商协议,都使用了Diffie-Hellman,它们基本上可以看成是Diffie-Hellman的扩展。
也就是说,群组密钥协商协议可以理解成如何使用Diffie-Hellman来实现群的密钥交换。
2. DH密钥协商算法2.1 算法的产生Diffie-Hellman密钥交换协议是第一个被提出的密钥协商方案,是美国斯坦福大学的W.Diffie和M.E.Hellman于1976年提出的,它是第一个发表的公钥密码体制,Diffie-Hellman算法的唯一目的就是使两个用户能安全的交换密钥,从而得到一个共享的会话密钥(秘密密钥)。
需要注意的是,该算法本身不能用于加密解密,只能用于密钥的交换,双方确定要用的密钥后,要使用其他对称密钥操作加密算法实际加密和解密消息。
2.2 算法的描述1. 离散对数的概念:1)原根:如果a是素数p的一个原根,那么数值:a mod p,a^2 mod p,…,a^(p-1) mod p是各不相同的整数,且以某种排列方式组成了从1 到p-1 的所有整数。
2)离散对数:如果对于一个整数b和素数p的一个原根a,可以找到一个唯一的指数i,使得b =(a^i)mod p,其中0≦i≦p-1,那么指数i称为b的以a为基数的模p的离散对数。
2. 算法有效性Diffie-Hellman 算法的有效性依赖于计算离散对数的难度,其含义是:当已知大素数p和它的一个原根a后,对给定的b,要计算i ,被认为是很困难的,而给定i 计算b 却相对容易。
3. Diffie-Hellman算法:假如用户A和用户B希望交换一个密钥。
取素数p和整数a,a是p的一个原根,公开a和p。
1)A选择大的随机数RA(0<=RA<=p-2),并计算SA=(a^RA) mod p,并且把SA发送给用户B。
2)B选择随机数RB(0<=RB<=p-2),并计算SB=(a^RB) mod p,并且把SB 发送给用户A。
3)A计算密钥的方式是:K=(SB) ^RA mod p,B计算密钥的方式是:K=(SA) ^RB mod p,证明:(SB)^ RA mod p = (a^RB mod p)^ RA mod p= (a^RB)^ RA mod p= (a^RA) ^RBmod p(-- 密钥即为 a^(RA*RB) mod p)=(a^RA mod p)^ RB mod p= (SA) ^RB mod p由于RA和RB是保密的,而第三方只有p、a、SB、SA可以利用,只有通过取离散对数来确定密钥,但对于大的素数p,计算离散对数是十分困难的。
4. 例子:假如用户Alice和用户Bob希望交换一个密钥,取一个素数p =97和97的一个原根a =5,Alice和Bob分别选择秘密密钥RA=36和RB=58 ,并计算各自的公开密钥:SA=a^RA mod p =5^36 mod 97=50SB=a^RB mod p =5^58 mod 97=44Alice和Bob交换了公开密钥之后,计算共享密钥如下:Alice:K=(SB) ^RA mod p=44^36 mod 97=75Bob:K=(SA) ^RB mod p=50^58 mod 97=75Diffie-Hellman密钥交换协议的基本模式如图2-1所示:2.3 算法的安全性当然,为了使这个例子变得安全,必须使用非常大的RA, RB 以及p,否则可以实验所有的可能取值。
(总共有最多97个这样的值, 就算RA和RB很大也无济于事)。
如果p 是一个至少 300 位的质数,并且RA和RB至少有100位长,那么即使使用全人类所有的计算资源和当今最好的算法也不可能从a, p和a^(RA*RB) mod p 中计算出 RA*RB。
这个问题就是著名的离散对数问题。
注意g则不需要很大, 并且在一般的实践中通常是2或者5。
在最初的描述中,迪菲-赫尔曼密钥交换本身并没有提供通讯双方的身份验证服务,因此它很容易受到中间人攻击。
一个中间人在信道的中央进行两次迪菲-赫尔曼密钥交换,一次和Alice另一次和Bob,就能够成功的向Alice假装自己是Bob,反之亦然。
而攻击者可以解密(读取和存储)任何一个人的信息并重新加密信息,然后传递给另一个人。
因此通常都需要一个能够验证通讯双方身份的机制来防止这类攻击。
有很多种安全身份验证解决方案使用到了迪菲-赫尔曼密钥交换。
例如当Alice和Bob共有一个公钥基础设施时,他们可以将他们的返回密钥进行签名。
有攻击的Diffie-Hellman密钥交换协议如图2-2所示:图2-2 有攻击的Diffie-Hellman密钥交换协议3. DH密钥协商算法的实现3.1 设计要求3.1.1 功能要求(1)产生一个奇数错误!未找到引用源。
,判断是否是素数。
素数要求介于2^14-2^15。
先用小于20的素数去试除,再使用Miller-Rabin概率检测算法进行检测;(2)求得模p 的一个原根,要求原根的值介于32-1024之间;(3)输出双方选择的随机数,随机数介于2^5-2^7,使用模重复平方法进行计算,输出双方的计算结果;(4)网络传输方面,可以是C/S模式,也可以是B/S模式;(5)输出最后协商的密钥;3.1.2 输出要求(1)输出奇数的产生过程,用函数实现产生满足要求的奇数;(2)输出用小素数试除的判断过程,并输出每次试除之后的余数,用函数实现一次试除并返回试除之后的余数;(3)Miller-Rabin概率检测算法运行5次,输出检测过程及结果。
用函数实现一次Miller-Rabin概率检测算法并返回检测结果;(4)如果不是奇素数,输出下一个奇数产生的规则;(5)输出产生模错误!未找到引用源。
的一个原根的过程;(6)输出使用模重复平方法进行计算的过程和结果。
3.2 模块划分及实现3.2.1 小素数试除算法描述:小素数试除主要是用随机产生的数来试除小于20的素数,以此简单判定该随机数是否是素数。
实现方式:以本次程序编写为例,取小素数数组S_PrimeTable[7] = { 3, 5, 7, 11, 13, 17, 19 },用产生的大随机数来除以数组中的元素,若所得余数不为0,则能暂时判断该随机数为素数。
具体实现代码如下:int SPrime(int odd){int i, remainder, k = 0;for (i = 0; i<7; i++){remainder = odd % S_PrimeTable[i];printf("第%d次小素数%d试除的余数为%d.\n", i + 1,S_PrimeTable[i], remainder);if (remainder == 0)k++;}if(!k){printf("小素数试除判断%d是素数。
\n\n",odd);}else{printf("小素数试除判断%d不是素数。
\n\n",odd);}return !k;}3.2.2 模重复平方法算法描述:模重复平方法是对大整数模m和大整数e计算b^e(mod m)。
在本次设计中,模重复平方法主要使用在米勒检测算余值部分、求原根部分、SA 和SB的计算以及最后密钥的计算过程中,其中,SA和SB的计算以及最后密钥的计算要求输出计算过程。
(为了界面显示美观,在此写了两个模重复平方算法的代码,思路相同,只是在其中一个函数中写了输出计算过程,该函数用来计算SA和SB以及最后的密钥。
)实现方式:令a=1,并将十进制数e写成二进制,若二进制数值为1,则计算a≡(a*b)mod n,b≡(b*b)mod n;若二进制数值为0,则计算a≡a mod n,b≡(b*b)mod n。
最后a即为最终计算结果。
具体实现代码如下:int MoChongFu(int m, int e,int n){int binary[22];int count=0,i;int a=1,b;b=m;do{binary[count]=e%2;e=e/2;count++;}while(e!=0);for(i=0;i<count;i++){if(binary[i]==1){a=(a*b)%n;b=(b*b)%n;//printf("a=%d, b=%d\n",a,b);}if(binary[i]==0){a=a;b=(b*b)%n;//printf("a=%d, b=%d\n",a,b);}}return a;}3.2.3 Miller-Rabin检测算法算法描述:米勒检测在本次设计中主要用来检测在小素数判定了之后的随机数是否是素数。
实现方式:将待检测的数n写成n-1=2s*t,选取随机数a,计算b≡atmod n。