RSA算法C语言代码Word版.doc

上传人:rrsccc 文档编号:9419330 上传时间:2021-02-24 格式:DOC 页数:5 大小:21.50KB
返回 下载 相关 举报
RSA算法C语言代码Word版.doc_第1页
第1页 / 共5页
RSA算法C语言代码Word版.doc_第2页
第2页 / 共5页
RSA算法C语言代码Word版.doc_第3页
第3页 / 共5页
RSA算法C语言代码Word版.doc_第4页
第4页 / 共5页
RSA算法C语言代码Word版.doc_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

《RSA算法C语言代码Word版.doc》由会员分享,可在线阅读,更多相关《RSA算法C语言代码Word版.doc(5页珍藏版)》请在三一文库上搜索。

1、传播优秀Word版文档 ,希望对您有帮助,可双击去除!#include #include #include #include #include char s100,*c;int n,e,d,i,C,j,k=0,len;int str100,b30;unsigned gcd(unsigned a, unsigned b )if(a%b=0)return b; else return gcd(b,a%b);void Egcd(int a, int b,int &x, int &y) /ax-by=1 if(b=0|a=0) x=1; y=0; return ; if(ab) Egcd(a,b%a,

2、x,y); x=(int)(b*y+1)/a; else Egcd(a%b,b,x,y); y=(int)(a*x-1)/b; void RSA()int p,q,N,Y; printf(请输入素数p和q:); scanf(%d %d,&p,&q); n=p*q;传播优秀Word版文档 ,希望对您有帮助,可双击去除! N=(p-1)*(q-1); /printf(n=%d N=%dn,n,N); srand( (unsigned)time( NULL ) ); /初始化随机数 while(1) /产生随机整数e,e与N互质 e=rand()%N;/ printf(e=%dn,e); if(e=

3、0) continue; if(gcd(N,e)=1) break; /printf(e=%dn,e); Egcd(e,N,d,Y); / printf(d=%d Y=%dn,d,Y); printf(公钥PU=e=%d,n=%dn,e,n); printf(私钥PR=d=%d,n=%dn,d,n);void encrypt() /加密函数len=strlen(s);/hgprintf(len=%dn,len); for(i=0;ilen;i+) /去掉s100中的空格 if(si122) bk=i; k+; for(j=i;jlen-1;j+) sj=sj+1; len-; slen=0;

4、/结束符printf(密文是:); for(i=0;ilen;i+)传播优秀Word版文档 ,希望对您有帮助,可双击去除! C=1; /printf(shiji=%dn,si-97);for(int j=0;je;j+)C=(C*(si-97)%n;/printf(C=%ldn,C); stri=C;printf(%d ,stri);printf(n); void decrypt() /解密函数c=(char*)malloc(len*sizeof(int); for(i=0;ilen;i+) /实现解密 C=1;for(int j=0;jd;j+)C=(C*(stri)%n;/printf(C

5、=%ldn,C);/printf(C=%dn,C); ci=C+97; ci = 0; / puts(c);for(int z=0;zk;z+) /加空格 for(i=0; ii;j-) cj=cj-1; ci= ; len+; bz+1=bz+1+(z+1); break;传播优秀Word版文档 ,希望对您有帮助,可双击去除! clen = 0; printf(明文:); puts(c);int function()/系统功能选择页面 int choice; printf(=n); printf( 欢迎进入RSA算法 n); printf( 1-加密 n); printf( 2-解密 n);

6、 printf( 3-退出 n); printf(=n); printf(请输入要选择的功能号:); scanf(%d,&choice); return choice;int main() int function(); int fc; printf(请输入初始明文(小写):); gets(s); / puts(s); RSA(); /提供私钥和公钥 while(1) fc=function(); if(fc=1) /加密 encrypt(); else if(fc=2) /解密decrypt() ; else if(fc=3) break; else printf(输入有误,请重新输入!/n); return 0;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 社会民生


经营许可证编号:宁ICP备18001539号-1