server.cpp代码:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include<stdio.h>
#include<string.h>
const int changdu = 9;
int c[90000];
//求e关于模(p-1)(q-1)的逆元d:即私钥
//加密函数
void encrypt(int e,int n){ //自己指定指数e
//先将符号明文转换成字母所对应的ascii码。
char mingwen[100]; //符号明文
printf("input the plaintxt:\n");
scanf("%s",mingwen);
//gets(mingwen);
int ming[strlen(mingwen)]; //定义符号明文
for(int i=0;i<strlen(mingwen);i++){
ming[i]=mingwen[i]; //将字母转换成对应的ascii码。
printf("%d",mingwen[i]); //将字母转换成对应的ascii码。可以不打印
}
printf("\n");
//开始加密
printf("start…………………………\n");
int zhuan=1; //c为加密后的数字密文
for(int i=0;i<strlen(mingwen);i++){
for(int j=0;j<e;j++){
zhuan=zhuan*ming[i]%n;
//zhuan=zhuan%n;
}
c[i]=zhuan;
//printf("%d",mi[i]);
zhuan=1;
}
printf("ciphertext:\n");
for(int i=0;i<strlen(mingwen);i++)
printf("%d",c[i]);
//创建套接字
int serv_sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
//将套接字和IP、端口绑定
struct sockaddr_in serv_addr;
memset(&serv_addr, 0, sizeof(serv_addr)); //每个字节都用0填充
serv_addr.sin_family = AF_INET; //使用IPv4地址
serv_addr.sin_addr.s_addr = inet_addr("127.0.0.1"); //具体的IP地址
serv_addr.sin_port = htons(1234); //端口
bind(serv_sock, (struct sockaddr*)&serv_addr, sizeof(serv_addr));
//进入监听状态,等待用户发起请求
listen(serv_sock, 20);
//接收客户端请求
struct sockaddr_in clnt_addr;
socklen_t clnt_addr_size = sizeof(clnt_addr);
int clnt_sock = accept(serv_sock, (struct sockaddr*)&clnt_addr, &clnt_addr_size);
//向客户端发送数据
write(clnt_sock, (char*)c, 90000);
//关闭套接字
close(clnt_sock);
close(serv_sock);
}
int main(){
int q,p,e,d,n,t;
p = 17;
q = 13;
e = 7;
d = 55;
n=q*p;
t=(q-1)*(p-1);
printf("t=(q-1)*(p-1)=%d\n",t);
printf("密钥为:%d",d);
printf("\n");
encrypt(e,n);
return 0;
}
client.cpp代码:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/socket.h>
#include<stdio.h>
#include<string.h>
const int changdu = 9;
int c[90000];
//解密函数
void decrypto(int d,int n){
//创建套接字
int sock = socket(AF_INET, SOCK_STREAM, 0);
//向服务器(特定的IP和端口)发起请求
struct sockaddr_in serv_addr;
memset(&serv_addr, 0, sizeof(serv_addr)); //每个字节都用0填充
serv_addr.sin_family = AF_INET; //使用IPv4地址
serv_addr.sin_addr.s_addr = inet_addr("127.0.0.1"); //具体的IP地址
serv_addr.sin_port = htons(1234); //端口
connect(sock, (struct sockaddr*)&serv_addr, sizeof(serv_addr));
//读取服务器传回的数据
read(sock, (char*)c, 90000);
close(sock);
int de_mingwen[changdu],zhuan1=1;
char de_ming[changdu];
for(int i=0;i<changdu;i++){
for(int j=0;j<d;j++){
zhuan1=zhuan1*c[i]%n;
//zhuan=zhuan%n;
}
de_mingwen[i]=zhuan1;
zhuan1=1;
}
printf("start…………………………\n");
printf("\n");
printf("the plaintxt is:\n");
for(int i=0;i<changdu;i++){
de_ming[i]=de_mingwen[i];
printf("%c",de_ming[i]);
}
}
int main(){
int q,p,e,d,n,t;
p = 17;
q = 13;
e = 7;
d = 55;
n=q*p;
t=(q-1)*(p-1);
decrypto(d,n);
return 0;
}
已在Ubuntu20.04下通过验证。