RSA算法实验代码.docx_第1页
RSA算法实验代码.docx_第2页
RSA算法实验代码.docx_第3页
RSA算法实验代码.docx_第4页
RSA算法实验代码.docx_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

RSA算法实验代码#include #define MAX_NUM 63001#define MAX_PRIME 251/! 返回代码#define OK 100#define ERROR_NOEACHPRIME 101#define ERROR_NOPUBLICKEY 102#define ERROR_GENERROR 103unsigned int MakePrivatedKeye( unsigned int uiP, unsigned int uiQ );unsigned int GetPrivateKeye( unsigned int iWhich );unsigned int MakePairkey( unsigned int uiP, unsigned int uiQ, unsigned int uiD );unsigned int GetPairKey( unsigned int &d, unsigned int &e );int rsa_encrypt( int n, int e, int mw,int p,int q);int rsa_decrypt( int n, int d, int cw, int p,int q);void outputkey();/!保存私钥d集合struct pKeysetunsigned int set MAX_NUM ;unsigned int size;pset;/! 保存公、私钥对struct pPairkeyunsigned int d;unsigned int e;unsigned int n;pairkey;/ 名称:isPrime/ 功能:判断两个数是否互质/ 参数:m: 数a; n: 数b/ 返回:m、n互质返回true; 否则返回falsebool isPrime( unsigned int m, unsigned int n )unsigned int i=0;bool Flag = true;if( m2 | n n ) ? n : m;for( i=2; i=tem & Flag; i+ )bool mFlag = true;bool nFlag = true;if( m % i = 0 )mFlag = false;if( n % i = 0 )nFlag = false;if( !mFlag & !nFlag )Flag = false;if( Flag )return true;elsereturn false;/ 名称:MakePrivatedKeye/ 功能:由素数P、Q生成公钥e/ 参数:uiP: 素数P; uiQ: 素数Q/ 返回:私钥dunsigned int MakePrivatedKeye( unsigned int uiP, unsigned int uiQ )unsigned int i=0;/! 得到所有与z互质的数( 私钥d的集合 )unsigned int z = ( uiP -1 ) * ( uiQ -1 );pset.size = 0;for( i=0; iz; i+ )if( isPrime( i, z ) )pset.set pset.size+ = i;return pset.size;/ 名称:MakePairKey/ 功能:生成RSA公、私钥对/ 参数:uiP: 素数P; uiQ: 素数Q; uiD: 私钥d/ 返回:错误代码unsigned int MakePairkey( unsigned int uiP, unsigned int uiQ, unsigned int uiD )bool bFlag = true;unsigned int i = 0, d;unsigned int z = ( uiP-1 ) * ( uiQ-1 );unsigned int e = pset.setuiD;if( !isPrime( z, e ) )return ERROR_NOEACHPRIME;for( i=2; i= iWhich )return pset.set iWhich ;elsereturn 0;/ 名称:rsa_encrypt/ 功能:RSA加密运算/ 参数:d: 公钥n; e: 私钥e; mw: 加密明文; cw: 密文输出/ 返回:无int rsa_encrypt( int d, int e,int mw, int p,int q)int i, j=0,cw;int temInt ;temInt = mw;i=p*q;/*/for( j=1; je; j+ )temInt = temInt * mw ;temInt = temInt % i;cw= temInt;return cw;/ 名称:rsa_decrypt/ 功能:RSA解密运算/ 参数:d: 公钥n; d: 私钥d; cw: 密文; cLength: 密文长度; mw: 明文输出/ 返回:无int rsa_decrypt( int d, int e, int cw, int p,int q )int i, j=-1,mw;int temInt = 0;i=p*q;mw= 0;temInt = cw;/printf(temInt %dn,temInt);/printf(d %d;e %dn; mW %d;p %d;q %d,d,e,cw,p,q);if( d != 0 )for( j=1; jd; j+ )temInt = temInt * cw ;/printf(temInt1 %dn,temInt);temInt=temInt% i;/printf(temInt2 %dn,temInt);mw = temInt;/printf(mw %dn,mw);return mw;void outputkey()printf(PublicKey(e,n): (%d,%d)n,pairkey.e,pairkey.n);printf(PrivateKey(d,n): (%d,%d)n,pairkey.d,pairkey.n);/! 程序主函数int main( )int mingwen ,miwen=0,miwen1,mw;unsigned int p , q , d , n , e;/two prime p & q, public key(n, e) , private key(n , d)printf(输入p:);scanf(%d,&p);printf(输入q:);scanf(%d,&q);while(isPrime(p,q)!=1)printf(输入的数不是质数,请重新输入n);printf(p:);scanf(%d,&p);printf(q:);scanf(%d,&q);n=MakePrivatedKeye(p, q);printf(产生的私钥的长度为%dn,n);printf(输入小于私钥长度的数:n);scanf(%d,&d);MakePairkey(p, q, d );outputkey();printf(请输入明文:n);scanf(%d,&mingwen);miwen=rsa_encrypt( pairkey.d , pairkey.e,mingwen,p,q);pri

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论