




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、简述大随机数生成程序的开发与测试摘要大随机数已经在当今社会的各个领域中都频繁使用,特别是在加密技术中已经成了不可缺少的一部分,像rsa,md5中随机数成为加密技术的关键。本设计主要为第3代移动通信系统(3g)提供符合要求的随机数(1024位),首先取得系统时间和rand()函数所产生的随机数作为最初的随机初值,经过三重des(两密钥通过md5算法得来)和异或的变换,保证其随机数的足够随机,然后通过16次的循环得到一个组合起来的1024位随机数,设计还提供一个检验随机数是否随机的平台,采用了均匀性检测,即频率检测的方法检测随机数的随机性,通过检测发现,所产生的随机数能够达到我们所期望的随机性。设
2、计还对常见的随机数的生成方法进行了检析,提供多种随机数的生成方法,并且也提供了多种随机数的检测方法供大家参考,希望对大家有所帮助。关键字:随机数;rsa;md5;加密技术;均匀性检测confidentialpagepage 2 of 24 210/1/2011big random number generator algorithm research and implementabstractthe big random number is used everywhere in modern society especially in the encryption technology. th
3、e random number is the key technology of the encryption.this design mainly provides the request random number (1024) for 3rd generation of mobile communication system. the way to provide the number is discussed in this article, and the randomness test is discussed too. there are many ways to finish
4、the task which are shown in this paper. we hope these techniques can be useful. key words: random number; rsa; md5; encryption technology; even line of examination目 录论文总页数: 19页1 引言11.1随机数的概念11.2课题背景11.3 国内外研究现状11.4 本课题研究的意义11.5 本课题的研究方法12常见随机数生成方法简析22.1 迭代取中法22.2 乘同余法22.3 混同于法22.4 反变换法32.4.1 平均分布 :3
5、2.4.2 指数分布 :42.4.3 正态分布随机变量的生成 :42.5 离散型随机变量43随机数的检验54 大随机数产生的机理64.1 流程图64.2 des算法简介75 算法实现86 检验随机数137 系统测试14结 论16参考文献17致 谢18声 明191 引言1.1随机数的概念在现今的计算机中所产生的随机数,都是伪随机数。即,可以通过一定手段和方法发现或破译其中的规律。真随机数,也有了一定的研究,比如:通过声音或原子衰变等所产生的随机数。伪随机数可以通过一定的数学算法,近似真随机数但仍然不是真随机数。1.2课题背景随机数已经在当今社会的各个领域中都频繁使用,特别是在加密技术中已经成了不
6、可缺少的一部分,甚至很多加密技术的保密程度就取决于随机数。像rsa,md5需求大量随机数的密码技术正需求一个好的随机数发生器的产生。如今很多随机数产生器已经存在,但那些都存在很多的不足,比如产生的随机数位数不够,不是足够随机等等问题,所以编制一个能够产生我们需要足够大的且足够随机的随机数的随机数产生器就变得很重要。1.3 国内外研究现状通过查阅质料和在网上了解,国外对随机数的研究领先于国人对随机数的研究,但是总体来说对随机数的研究都还不够深入与透彻,都还不能脱离伪随机数的阴影,但的确目前的技术支持与环境配置等方面都还制约着我们大多数只能在研究伪随机数的层面,我们只可能的尽量地做到无限接近真随机
7、数,而不能达到真正的随机。特别在随机数的检测这方面,虽然检测的方法很多,但是都不够完善,没有一个很公用很全面的检测方法诞生,所以在随机数的研究中还有很深的东西需要我们去挖掘。1.4 本课题研究的意义保证我们能够很快速的得到需要的随机数,而且随机数能够足够大足够随机,尽量能够实用在需要用到随机数的任何地方,特别是在科研领域,比如第3代移动通信系统(3g)中需要的1024随机数,就能满足它的要求,我们所要做的就是使产生的随机数尽量的靠近真随机数。1.5 本课题的研究方法工作任务:1.大致了解随机数产生器的发展过程和现阶段的大概情况,认识现阶段随机数产生器的产生方式和所用到的知识,结构体系是怎样的。
8、2.分析他们的优点和缺点,能够保留的优点就要尽量用到,如果有不足应该怎样改正,加上自己的理解和题目的要求做一个满意的随机数产生器。要求: 使用vc+平台,编写一个能产生1024位的随机数发生器,而且随机数还要是足够随机的,并且还要编制一个检验平台,能在该平台上检验该随机数是足够随机的。设计思路:采用vc+6.01使用vc+实现控件的开发与界面的设计,尽量使外观简单容易实用,输出结果方便易看2借鉴其他随机数产生器的产生方法,参阅aes,des中随机数的产生方法,借鉴出其中的精华,补上自己的构思与想法尽量使随机数不出现重复。2常见随机数生成方法简析2.1 迭代取中法这里在迭代取中法中介绍平方取中法
9、 , 其迭代式如下 : xn+1=(xn2/10s)(mod 102s) rn+1=xn+1/102s 其中, xn+1 是迭代算子,而 rn+1 则是每次需要产生的随机数。 第一个式子表示的是将 xn 平方后右移 s 位,并截右端的 2s 位。 而第二个式子则是将截尾后的数字再压缩 2s 倍,显然 :0=<rn+1<=1. 迭代取中法有一个不良的性就是它比较容易退化成 0。2.2 乘同余法乘同余法的迭代式如下 : xn+1=lamda*xn(mod m) (lamda 即参数 ) rn+1=xn/m 各参数意义及各步的作用可参 2.1。当然,这里的参数的选
10、取至关重要。 经过前人检验的两组性能较好的素数取模乘同余法迭代式的系数为 : 1 ) lamda=55,m=235-31 2 ) lamda=75,m=231-12.3 混同于法 混合同余法是加同余法和乘同余法的混合形式 , 其迭代式如下 : xn+1=( lamda*xn+c )%m rn+1=xn/m 经前人研究表明,在 m=2q 的条件下,参数 lamda,miu,x0 按如下选取,周期较大,概率统计特性好 : lamda=2b+1,b 取 q/2 附近的数 c=(1/2+sqrt(3)/m x0 为任意非负整数 它
11、的一个致命的弱点,那就是随机数的生成在某一周期内成线性增长的趋势,显然,在大多数场合,这种极富“规律”型的随机数是不应当使用的。实现 : 1 double _random( void ) 2 3 int a; 4 double r; 5 6 a = rand() % 32767 ; 7 r = (a + 0.00 ) / 32767.00 ; 8 9 return r; 10 11 2.4 反变换法它首先需要使用均匀分布获得一个 (0,1) 间随机数 , 这个随机数相当于原概率分布的 y 值 , 因
12、为我们现在是反过来求 x. 哎 , 听糊涂了也没关系 , 只要知道算法怎么执行的就行 . 采用概率积分变换原理 , 对于随机变量 x 的分布函数 f(x) 可以求其反函数,得 : 原来我们一般面对的是概率公式 y=f(x). 现在反过来 , 由已知的概率分布或通过其参数信息来反求 x. xi=g(ri) 其中 ,ri 为一个 0-1 区间内的均匀分布的随机变量 . f(x) 较简单时,求解较易,当 f(x) 较复杂时,需要用到较为复杂的变换技巧。 2.4.1 平均分布 :2.4.2 指数分布 : 2.4.3 正态分布随机变量的生成 : 2.5 离散型随机变量3 随机数的检验随机数的统计检验,就
13、是根据(0,1)上均匀总体简单子样式的性质来研究所产生的随机数序列的相应性质,进行比较鉴别,视其差异显著与否,决定取舍。如果所产生的伪随机数经过各类检验,其差异均不显著,我们即接受其为均匀总体随机数的子样。需要指出的是,若所产生的伪随机数序列通过某种随机性检验,只是说它与随机数的性质和规律不矛盾,我们不能扛绝它,并不是说它们已经具有随机数的性质与规律。因此检验所产生的伪随机数序列时,所通过的检验越多,随机数序列就越靠得住。随机数的检验方法有:参数检验,检验其分布参数的观察值与理论值的差异显著性。均匀性检验,又称频率检验,意在检验伪随机数的经验频率与理论频率的差异是否显著。独立性检验,即检验所产
14、生的伪随机数的独立性和统计相关是否异常,包括相关关系检验和联列表检验等。组合规律检测,按随机数出现的先后次序,根据一定的规律组合,检验其组合的观察值与理值是不否有显著差异,包括距离检验和配套检验等。游程检验,把随机数序列按一定的规则进行分类,分为正负游程检验和升降游程检验等。4 大随机数产生的机理4.1 流程图图1 1024位随机数产生原理图伪随机数产生器的产生过程:输入: 输入为两个64比特的伪随机数dti和vi,其中dti表示当前的日期和时间,每产生一个数ri后,dti都更新一次;vi是产生第i个随机数时的种子,其初值可任意设定,以后每次自动更新。密钥: 产生器用了3次三重des加密,3次
15、加密使用相同的两个56比特的密钥k1和k2,这两个密钥必须保密且不能用作他用。输出: 输出为一个64比特的伪随机数ri和一个64比特的新种子vi+1step_1: 使用两个56比特的密钥k1和k2,对伪随机数dti进行一次三重des加密(ede),得到result_1;step_2: 任意设置一个值为vi的初值,将vi和result_1进行异或,得到result_2;step_3: 使用密钥k1和k2对result_2进行一次三重des加密(ede),得到一个64bit的ri和result_3;(公式1)(说明: ede表示两个密钥的三重des)step_4: 异或result_1和resul
16、t_3,得到result_4;step_5: 使用密钥k1和k2对result_4进行一次三重des加密(ede),得到result_5,即得到一个64bit的新种子v(i+1).(公式2)(说明: ede表示两个密钥的三重des)step_6: v(i+1)将作为下一轮的输入vi,再次循环完成step_1到step_5的过程,直到完成16轮迭代加密.本方案具有非常高的密码强度,这是因为采用了112比特长的密钥和9个des加密,同时还由于算法由两个伪随机数输入驱动,一个是当前的日期和时间,另一个是算法上次产生的新种子。而且即使某次产生的随机数ri泄露了,但由于ri又经一次ede加密才产生新种子
17、vi+1,所以别人即使得到ri也得不到vi+1,从而得不到新随机数ri+1。随机数产生为1024位,即16组64位2进制数,且有最高为(第1024位2进制数)为1,所以该随机数高位在(16进制)10000000与ffffffff之间。4.2 des算法简介自des算法1977年公诸于世以来,人们一直对des的安全性持怀疑态度,对密钥的长度、迭代次数及s盒的设计众说纷纭。从技术上说,对des的批评主要集中在以下3个方面:作为区组密码,des的加密单位仅有64位二进制,对于数据传输来说太小;密钥仅有56位二进制未免太短,各次迭代中使用的密钥k(i)是递推产生的,这种相关性降低了密码体制的安全性;实
18、现替代函数si所用的s盒的设计原理尚未公开,其中可能留有隐患。针对以上des的缺陷,人们提出了几种增强des安全性的方法,主要有以下3种:1) 三重des算法用3个不同密钥的三重加密,即为:c=ek3(dk2(ek1p)p=dk1(ek2(dk3c) 该方法为密码专家默克尔(merkle)及赫尔曼(hellman)推荐。据称,目前尚无人找到针对此方案的攻击方法。2)具有独立子密钥的des算法每一轮迭代都使用一个不同的子密钥,而不是由一个56位二进制的密钥产生。由于16轮迭代的每轮使用一个48位二进制的密钥,所以这一方法可以增强des的加密强度。3)带有交换s盒的des算法比哈姆和沙米尔证明通过
19、优化s盒的设计,甚至s盒本身的顺序,可以抵抗差分密码分析,以达到进一步增强des算法的加密强度的目的。5 算法实现函数名: get_systemstatus_w32函数功能: 得到系统状态输入: 无输出: 系统状态字符串,ni:得到的字符串长度流程图:进程id的句柄标实符线程的句柄标实符cpu脉冲值内存状态字凡是长度大于maxlen ,ni等于ni加上其长度,返回ni图2 得到系统状态的方法示意图buf: 用以保存系统状态字符中,maxlen:字符串长度int ccrerndnum:get_systemstatus_w32(int maxlen) int ni = 0; /保存得到的字符串长度
20、dword dwres;memorystatus ms;dwres = getcurrentprocessid(); /返回长整型(dword)if (maxlen >= sizeof(dword)memcpy(&bufni, &dwres, sizeof(dwres);ni += sizeof(dwres);maxlen -= sizeof(dwres);dwres = getcurrentthreadid();if (maxlen >= sizeof(dword)memcpy(&bufni, &dwres, sizeof(dwres);ni +=
21、 sizeof(dwres);maxlen -= sizeof(dwres);dwres = gettickcount();if (maxlen >= sizeof(dword)memcpy(&bufni, &dwres, sizeof(dwres);ni += sizeof(dwres);maxlen -= sizeof(dwres);ms.dwlength = sizeof(memorystatus);globalmemorystatus(&ms);if (maxlen >= sizeof(memorystatus)memcpy(&bufni,
22、&ms, sizeof(memorystatus);ni += sizeof(memorystatus);maxlen -= sizeof(memorystatus);return ni;void ccrerndnum:getkey() int sysinfolen = get_systemstatus_w32(300);cstring skey32; /字符串型int ikey3232; /转换后的整型 skey32 = cmd5checksum:getmd5(buf,sysinfolen);/字符串for(int i = 0; i < 32; i+)/字符串转化为整型ikey
23、32i = chartoint(skey32i);for(i = 0; i < 64; i+) /取出每一位kk1i = ikey32i / 4 >> (i % 4) & 0x01; kk2i = ikey3216 + i / 4 >> (i % 4) & 0x01; 函数名: gettime函数功能: 得到64bit的当前日期和时间的二进制输入: 系统时间输出: btime64算法示意图:通过移位异或把系统时间转换成二进制数并放到dti的高32和低32位中去通过摸除2得到64位的二进制随机数vidti和vi都将作为主程序的输入随机数输入系统时间r
24、and()产生的随机数图3 分别得到产生大随机数的输入随机数void ccrerndnum:gettime()int i;filetime ft;getsystemtimeasfiletime(&ft);for (i = 0; i < 32; i+) dti31 - i = (char)(ft.dwhighdatetime >> i) & 0x01); / 取得各位的值 dti63 - i = (char)(ft.dwlowdatetime >> i) & 0x01);void ccrerndnum:getvi() /得到64位的二进制随机
25、数int i; srand(unsigned)time(null); for (i = 0; i < 64; i+)vii = rand()%2;函数名: step_1函数功能: 产生随机数第1步(见图1)输入: dti(时间),k1,k2(密钥)输出: result_164调用函数: mydes:ede()void ccrerndnum:step_1()gettime(); /得到时间二进制并保存在dti中 getkey(); /产生密钥并保存在kk1,kk2中cdes mydes;mydes.ede (dti, kk1, kk2, result_1); /三重des加密(ede)函数
26、名: step_2函数功能: 产生随机数第2步(见图1)输入: result_1,vi(第一次输入的随机数)输出: result_264void ccrerndnum:step_2()int i;/之前已得到v0for (i = 0; i < 64; i+)result_2i = vii result_1i;函数名: step_3函数功能: 产生随机数第3步(见图1)输入: result_2,k1,k2(密钥)输出: result_364调用函数: mydes:ede()void ccrerndnum:step_3()cdes mydes;mydes.ede(result_2, kk1,
27、 kk2, result_3);函数名: step_4函数功能: 产生随机数第4步异或(见图1)输入: result_1,result_3输出: result_464void ccrerndnum:step_4() int i; for (i = 0; i < 64; i+) result_4i = result_1i result_3i; 函数名: step_5函数功能: 产生随机数第5步(见图1)输入: result_4,k1,k2(密钥)输出: result_564调用函数: mydes:edevoid ccrerndnum:step_5()cdes mydes;mydes.ede
28、 (result_4, kk1, kk2, result_5);函数名: getrandnumber函数功能: 产生随机数,保存在dwrndnum33中.输入: 无输出: dwrndnum33备注: 输出1025位二进制,故用33个dword型的数存放随机数.bool ccrerndnum:getrandnumber(dword dwrndnum) getvi(); int i,m;for (m = 0; m < 17; m+) /17轮产生1088(取1025)位的ristep_1(); step_2(); step_3(); for (i = 0; i < 64; i+) ri
29、(m << 6) + i = result_3i; /保存到1024bit的ri中 step_4(); step_5(); for (i = 0; i < 64; i+) /vi+1自动赋给vi vii = result_5i; / end for uint temp;for ( i = 0; i < 1024; i+) /取第11024位temp = (uint)(i / 32);if(i % 32 = 0) dwrndnumtemp = dwrndnumtemp | (dword)rii; else dwrndnumtemp = dwrndnumtemp <&
30、lt; 1 | (dword)rii;for(i=0;i<32;i+)while(dwrndnumi<2147483648)dwrndnumi+=dwrndnumi; dwrndnum32 &= (dword)ri1024; /取第1025位,其余位为0return true; 6 检验随机数随机数检验方法有如下几种:参数检验,检验其分布参数的观察值与理论值的差异显著性。均匀性检验,又称频率检验,意在检验伪随机数的经验频率与理论频率的差异是否显著。独立性检验,即检验所产生的伪随机数的独立性和统计相关是否异常,包括相关关系检验和联列表检验等。组合规律检测,按随机数出现的先后次序,根据一定的规律组合,检验其组合的观察值与理值是不否有显著差异,包括距离检验和配套检验等。游程检验,把随机数序列按一定的规则进行分类,分为正负游程检验和升降游程检验等。本程序采用了均匀性检测,即频率检测。由于随机数是由16次循环得来。并且存放在32个数组中,所以取其中高位数组的值就可以判断是否满足均匀性检测。算法示意图: 随机数除于当前随机数产生的次数如果第一次产
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 工业互联网平台计算机视觉缺陷检测技术2025年应用在环保行业的创新与挑战
- 2025【校区环境整治项目合同书】校区绿化工程合同书
- 金融科技企业估值与2025年投资风险控制的策略研究报告
- 农业废弃物堆肥在2025年农业废弃物处理行业中的应用前景及挑战报告
- 深入探讨2025年学前教育信息化对幼儿园教育评价体系的影响报告
- 农产品溯源2025年质量安全追溯体系与农业现代化进程报告
- 2025年主题公园沉浸式体验项目开发中的旅游市场拓展策略研究报告
- 城市污水处理厂智能化升级改造的运行管理优化报告
- 音乐教学经验总结模版
- 高校生教育实习个人工作总结模版
- 《凝结水精处理》课件
- 大学答题纸模板
- 福建省宁德福鼎市2024-2025学年七年级上学期期中考试语文试题
- 福建省普通高中6月学业水平合格性考试英语试题(含答案解析)
- 【MOOC】Office高级应用-成都信息工程大学 中国大学慕课MOOC答案
- 《化工新材料生产技术》课件-知识点1 聚酰胺概述
- 医院患者信息保密管理制度
- 心肺复苏完整版本
- 五一收心安全教育培训
- 220kV变电站电气设备常规交接试验方案
- 银行比较新颖的沙龙活动
评论
0/150
提交评论