{ rsa }

  • 01 生成公钥和私钥

    /

    01 生成公钥和私钥

    #include <botan/auto_rng.h>
    <!--more-->
    #include <botan/rsa.h>
    #include <botan/pkcs8.h>
    #include <botan/x509_key.h>

    #include <iostream>

    int main() {
    try {
    Botan::AutoSeeded_RNG rng;

    // 生成 RSA 密钥对
    Botan::RSA_PrivateKey private_key(rng, 2048); // 2048 是密钥位数,你可以根据需要调整
    Botan::RSA_PublicKey public_key = private_key;

    // 输出公钥和私钥
    std::cout << "Public Key: " << Botan::X509::PEM_encode(public_key) << std::endl;
    std::cout << "Private Key: " << Botan::PKCS8::PEM_encode(private_key) << std::endl;

    }
    catch (std::exception& e) {
    std::cerr << "Error: " << e.what() << std::endl;
    return 1;
    }

    return 0;
    }

  • 02 保存公钥和私钥

    /

    02 保存公钥和私钥

    #include <botan/auto_rng.h>
    <!--more-->
    #include <botan/rsa.h>
    #include <botan/pkcs8.h>
    #include <botan/x509_key.h>
    #include <iostream>
    #include <fstream>

    void save_key_to_file(const std::string& filename, const std::string& key_data) {
    std::ofstream file(filename);
    if (file.is_open()) {
    file << key_data;
    file.close();
    std::cout << "Key saved to file: " << filename << std::endl;
    }
    else {
    throw std::runtime_error("Unable to open file for writing: " + filename);
    }
    }

    int main() {
    try {
    Botan::AutoSeeded_RNG rng;

    // 生成 RSA 密钥对
    Botan::RSA_PrivateKey private_key(rng, 2048); // 2048 是密钥位数,你可以根据需要调整
    Botan::RSA_PublicKey public_key = private_key;

    // 将公钥和私钥编码为 PEM 格式
    std::string public_key_pem = Botan::X509::PEM_encode(public_key);
    std::string private_key_pem = Botan::PKCS8::PEM_encode(private_key);

    // 保存公钥和私钥到文件
    save_key_to_file("public_key.pem", public_key_pem);
    save_key_to_file("private_key.pem", private_key_pem);

    }
    catch (std::exception& e) {
    std::cerr << "Error: " << e.what() << std::endl;
    return 1;
    }

    return 0;
    }