У меня есть открытый ключ, который хранится в переменной следующим образом:
static const char publicKey[] =
"-----BEGIN PUBLIC KEY-----\n\
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDCKFctVrhfF3m2Kes0FBL/JFeO\
cmNg9eJz8k/hQy1kadD+XFUpluRqa//Uxp2s9W2qE0EoUCu59ugcf/p7lGuL99Uo\
SGmQEynkBvZct+/M40L0E0rZ4BVgzLOJmIbXMp0J4PnPcb6VLZvxazGcmSfjauC7\
F3yWYqUbZd/HCBtawwIDAQAB\n\
-----END PUBLIC KEY-----";
Я хотел бы зашифровать с заполнением PKCS # 1 v1.5 (RSA_PKCS1_PADDING), но не могу понять, как загрузитьключ из памяти вместо файла:
void init()
{
RSA* rsa = RSA_new();
//what now?
//rsa = PEM_read_RSA_PUBKEY(file, &rsa, NULL, NULL); //requires a file
}
void encrypt(unsigned char* data, int length)
{
//can input buffer and output buffer be the same?
RSA_public_encrypt(length, data, data, rsa, RSA_PKCS1_PADDING);
}
Кроме того, нужно ли вызывать какой-либо код очистки?