一、前言
看了网上在RSA加密解密,给出的例子中都是只能对很小的一段内容进行加密和解密,如果超出了一定的长度加解密程序机会出错。
例:采用公钥加密私钥解密,给出的key是1024bit的话,一次性只能加密117个字节块,如果不足117块按117块处理返回的是128块加密密文,那么对应私钥解密只能解密128字节块,得出的明文是117字节块。key转换具体加密字节块公式
二、编译Openssl
参考 openssl编译
三、C/C++示例程序
enum CryptoType
{
PRIVATE_ENCRYPT = 0,
PRIVATE_DECRYPT,
PUBLIC_ENCRYPT,
PUBLIC_DECRYPT,
};
#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
#include <string.h>
#include "openssl/evp.h"
#include "openssl/bio.h"
#include "openssl/buffer.h"
#include "openssl/rsa.h"
#include "openssl/pem.h"
#include "openssl/err.h"
#include "rsa.h"
static R