RSA加密传输socket C++ Linux

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下通过验证。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值