#include<iostream.h>
#include <stdlib.h>
#include<math.h>
#include<String.h>
int r; //公开模数
int sk; //私人密钥
int pk; //公开密钥
int Euler;//欧拉函数
int check(int x)
{
for(int i=2;i<=x-1;i++)
{
if(x%i==0) break;
}
if(i==x) return 1;
else return 0;
}
void produceSS()
{
int p,q;
int flag=0;
int n=0;
cout<<"输入值不要太大,防止溢出!"<<endl;
while(flag==0)
{
if(n>0) cout<<"p应为素数,请重新输入!"<<endl;
cout<<"请输入素数p:";
cin>>p;
flag=check(p);
n++;
}
flag=0;
n=0;
while(flag==0)
{
if(n>0) cout<<"q应为素数,请重新输入!"<<endl;
cout<<"请输入素数q:";
cin>>q;
flag=check(q);
n++;
}
r=p*q;
cout<<"公开模数:r="<<r<<endl;
Euler=(p-1)*(q-1);
cout<<"欧拉函数:Euler="<<Euler<<endl;
}
int gcd(int x,int y)
{
int a=x;
int b=y;
int z;
b++;
do
{
b--;
x=a;
y=b;
while(x%y!=0)
{
z=x%y;
x=y;
y=z;
}
}while(z>1);
return b;
}
int trAsc(int s,int a[]) //转为二进制数
{
int x=s;
int n=0;
while(x!=0)
{
a[n]=x%2;
x=x/2;
n++;
}
return n;
}
int pfc(int x,int key) //平方乘
{
int a[13];
int m=trAsc(key,a); //二进制位数
int c=1;
for(int i=m-1;i>=0;i--)
{
c=c*c%r;
if(a[i]==1) c=c*x%r;
}
return c;
}
int producePk()
{
int a1=sk;
int r1=r;
int q1, p1;
int b1=0;
int b2=1;
int b3;
do{
cout<<a1<<endl;
p1=r1/a1;
q1=r1%a1;
b3=b1-b2*p1;
b1=b2;
b2=b3;
r1=a1;
a1=q1;
}while(a1!=1);
return abs(b2);
}
void produceKey()
{
int k;
int n=0;
int flag=0;
int b1=0;
int b2=1;
int a,c,q,p;
cout<<"初始密钥应小于欧拉函数:"<<r<<endl;
cout<<"请输入初始密钥:";
cin>>sk;
sk++;
do
{
sk--;
sk=abs(sk);
sk=gcd(Euler,sk);
b1=0;
b2=1;
a=sk;
c=Euler;
do
{
q=c/a;
p=c%a;
pk=b1-b2*q;
c=a;
a=p;
b1=b2;
b2=pk;
}while (p!=1);
pk=abs(pk);
a=pfc(8,sk);
c=pfc(a,pk);
} while(c!=8); //加密、解密正确判断
cout<<"私人密钥:sk="<<sk<<endl;
cout<<"公开密钥:pk="<<pk<<endl;
}
void Encryption() //加密
{
int Express;
int flag=1;
while(flag)
{
cout<<"明文编码应小于公开模数r:"<<r<<endl;
cout<<"请输入要加密的明文编码(十进制数):";
cin>>Express;
if(Express>r)
cout<<"明文编码应大于公开模数,请重新输入!"<<endl;
else flag=0;
}
cout<<"sk="<<sk<<endl;
cout<<"原编码为:"<<Express;
Express=pfc(Express,sk);
cout<<"密文为:"<<Express<<endl;
}
void Decrypt()//减密
{
int Express;
int flag=1;
while(flag)
{
cout<<"密文编码应小于公开模数r:"<<r<<endl;
cout<<"请输入要加密的密文编码(十进制数):";
cin>>Express;
if(Express>r)
cout<<"密文编码应大于公开模数,请重新输入!"<<endl;
else flag=0;
}
cout<<"pk="<<pk<<endl;
cout<<"原编码为:"<<Express;
Express=pfc(Express,pk);
cout<<"明文为:"<<Express<<endl;
}
void main()
{
int flag=1;
int step;
int n;
while(flag)
{
cout<<"1.产生素数"<<endl;
cout<<"2.产生密钥"<<endl;
cout<<"3.加密"<<endl;
cout<<"4.解密"<<endl;
cout<<"5.退出"<<endl;
cout<<"请输入您的操作(1,2,3,4或5):";
cin>>step;
switch(step)
{
case 1:produceSS();
break;
case 2:produceKey();
break;
case 3:Encryption();
break;
case 4:Decrypt();
break;
case 5:exit(0);
break;
}
}
}
afunti
- 粉丝: 25
- 资源: 41
最新资源
- 7.(备用)180题自动计算结果(6不能用则用7).xls
- 机械设计饲料搅拌机sw18全套设计资料100%好用.zip
- DISC测试题目(详细版).doc
- DISC评分表格.xls
- Java项目:校园周边美食探索(java+SpringBoot+Mybaits+Vue+elementui+mysql)
- 明达集团招聘管理制度-终.doc
- 招聘与录用管理制度.doc
- 标准HR面试话术.doc
- 经理面试话术.doc
- 大学远程教育-计算机网络试卷题目.docx
- 技术人员面试话术.doc
- 电话邀约销售面试话术.doc
- hr电话邀约面试考察话术.doc
- 面试预约话术.doc
- python入门5个经典案例含代码示例.docx
- 基于FPGA实验板的多功能数字时钟-利用Quartus实现设计与仿真源码+课程设计报告
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈