48 lines
1.1 KiB
C++
Raw Normal View History

2024-02-28 17:02:36 +08:00
#include <iostream>
#include <box_rsa.h>
#include <cassert>
using namespace cppbox;
CRSAOperator opr;
void file_test()
{
const char* pub = "public.pem";
const char* pri = "private.pem";
2024-02-28 17:29:42 +08:00
if (!opr.generate_keypair(pub, pri)) {
std::cout << opr.get_last_error() << std::endl;
}
2024-02-28 17:02:36 +08:00
HData source_data;
int size = 512;
source_data.len = size;
2024-02-28 17:06:02 +08:00
opr.alloc_hdata(source_data);
2024-02-28 17:02:36 +08:00
source_data.len = std::snprintf((char *)source_data.data, source_data.len, "This is a cryp test!");
HData en_result_data;
HData de_result_data;
if (!opr.encrypt_pub(pub, source_data, en_result_data)) {
std::cout << opr.get_last_error() << std::endl;
}
if (!opr.decrypt_pri(pri, en_result_data, de_result_data)) {
std::cout << opr.get_last_error() << std::endl;
}
assert(strcmp((const char *)de_result_data.data, (const char *)source_data.data) == 0);
opr.free_hdata(en_result_data);
opr.free_hdata(de_result_data);
remove(pub);
remove(pri);
std::cout << "cryp_test success!" << std::endl;
}
int main()
{
file_test();
return 0;
}