c++生成公钥和私钥并对字符串加密和解密

#include "cryptotest.h"  
#include <string.h>  
#include <stdio.h>  
#include <openssl/evp.h>
#include <openssl/x509.h>
#include <string.h>

const char *g_pPubFile = "public.pem";
const char *g_pPriFile = "private.pem";

//maxCodeByte = g_nBits/8-11
const int g_nBits = 1024;



int MakeKey()
{
	 /*if (access(g_pPubFile,0) != 0 || access(g_pPriFile,0) != 0)
	 {
	  return 0;
	 }*/
	 //生成key,这里设置了1024,意味着最多可以编解码1024/8-11=117个字节,
	 //RSA_F4为公钥指数,一般情况下使用RSA_F4即可,
	 //其它两个参数可以设置为NULL
	 RSA *pRsa = RSA_generate_key(g_nBits,RSA_F4,NULL,NULL);
	 if (pRsa == NULL)
	 {
		  printf("rsa_generate_key error");
		  return -1;
	 }
 	 BIO *pBio = BIO_new_file(g_pPubFile,"wb");

	 if (pBio == NULL)
	 {
		  printf( "BIO_new_file = %s  error",g_pPubFile);
		  return -2;
	 }
	 if(PEM_write_bio_RSAPublicKey(pBio,pRsa) == 0)
	 {
		  printf("write public key error");
		  return -3;
	 }
	 BIO_free_all(pBio);


	 pBio = BIO_new_file(g_pPriFile,"w");
	 if (pBio == NULL)
	 {
        	printf("BIO_new_file %s error ",g_pPriFile);
		return -4;
	 }
	 if(PEM_write_bio_RSAPrivateKey(pBio,pRsa,NULL,NULL,0,NULL,NULL) == 0)
	 {
		  printf("write private key error");
		  return -5;
	 }
	 BIO_free_all(pBio);
	 RSA_free(pRsa);
	 
	 return 0;
}


int Enc(char *in, int inLen, char *out, int * outLen)
{
	 BIO *pBio = BIO_new_file(g_pPubFile,"r");
	 RSA *pRsa = PEM_read_bio_RSAPublicKey(pBio,NULL,NULL,NULL);
	 BIO_free_all(pBio);
	 *outLen = RSA_public_encrypt(
	 		 (RSA_size(pRsa)-11)>inLen?inLen:RSA_size(pRsa)-11,
	        	(unsigned char *)(in),
		       (unsigned char *)(out),
	  		 pRsa,
	  		 RSA_PKCS1_PADDING);
	 //RSA_free(pRsa);
	 if(*outLen >= 0)
	  return 0;
	 return -1;
}


int Dec(char *in, int inLen, char *out, int * outLen)
{
	BIO *pBio = BIO_new_file(g_pPriFile,"r");
	RSA *pRsa = PEM_read_bio_RSAPrivateKey(pBio,NULL,NULL,NULL);
		BIO_free_all(pBio);
		*outLen = RSA_private_decrypt(
		inLen,
		(unsigned char *)(in),
		(unsigned char *)(out),
		pRsa,
		RSA_PKCS1_PADDING);
	//RSA_free(pRsa);
	if(*outLen >= 0)
	return 0;
	return -1;
}

int main()
{
	 MakeKey();
	 char pOld[100]="for test";
	 char szEnc[1024] = {0};
	 int nEncLen = 0;
	 char szDec[1024] = {0};
	 int nDecLen = 0;
	 Enc(pOld,strlen(pOld),szEnc,&nEncLen);
	 Dec(szEnc,nEncLen,szDec,&nDecLen);
	 printf( "szEnc: %s , nEncLen = %d\n", szEnc,nEncLen);
	 printf( "szDec: %s , nDecLen = %d\n", szDec,nDecLen);

	 return 0;
}



  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
使用RSA算法加密字符串的步骤如下: 1.生成RSA密钥对,包括公钥私钥。可以使用openssl库中的RSA_generate_key函数生成密钥对。 2.使用公钥对明文进行加密。可以使用openssl库中的RSA_public_encrypt函数进行加密。 3.使用私钥对密文进行解密。可以使用openssl库中的RSA_private_decrypt函数进行解密。 下面是一个使用openssl库实现RSA加密C++代码示例: ```c++ #include <openssl/rsa.h> #include <openssl/pem.h> int main() { // 生成RSA密钥对 RSA *keypair = RSA_generate_key(2048, RSA_F4, NULL, NULL); if (keypair == NULL) { printf("Failed to generate RSA key pair\n"); return -1; } // 明文 const char *plaintext = "Hello, world!"; // 计算加密后的密文长度 int ciphertext_len = RSA_size(keypair); unsigned char *ciphertext = new unsigned char[ciphertext_len]; // 使用公钥加密明文 int len = RSA_public_encrypt(strlen(plaintext) + 1, (unsigned char *)plaintext, ciphertext, keypair, RSA_PKCS1_PADDING); if (len == -1) { printf("Failed to encrypt plaintext\n"); return -1; } // 计算解密后的明文长度 int plaintext_len = RSA_size(keypair); unsigned char *decrypted = new unsigned char[plaintext_len]; // 使用私钥解密密文 len = RSA_private_decrypt(ciphertext_len, ciphertext, decrypted, keypair, RSA_PKCS1_PADDING); if (len == -1) { printf("Failed to decrypt ciphertext\n"); return -1; } // 输出解密后的明文 printf("Decrypted plaintext: %s\n", decrypted); // 释放内存 RSA_free(keypair); delete[] ciphertext; delete[] decrypted; return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值