(C++) RSA Encrypt and Decrypt Strings

(C++) RSA Encrypt and Decrypt Strings

C++ sample code to RSA public-key encrypt and decrypt strings using public and private keys.

Chilkat C/C++ Library Downloads

MS Visual C/C++

Linux/CentOS/Heroku C/C++

MAC OS X C/C++

C++ Builder

Solaris C/C++

iOS C/C++

Android C/C++

Raspberry Pi C/C++

Windows Mobile 5.0/Pocket PC 2003

ARM Embedded Linux C/C++

PowerLinux C/C++

FreeBSD C/C++

MinGW C/C++

#include <CkRsa.h>

void ChilkatSample(void)
    {
    CkRsa rsa;

    bool success = rsa.UnlockComponent("Anything for 30-day trial");
    if (success != true) {
        std::cout << "RSA component unlock failed" << "\r\n";
        return;
    }

    //  This example also generates the public and private
    //  keys to be used in the RSA encryption.
    //  Normally, you would generate a key pair once,
    //  and distribute the public key to your partner.
    //  Anything encrypted with the public key can be
    //  decrypted with the private key.  The reverse is
    //  also true: anything encrypted using the private
    //  key can be decrypted using the public key.

    //  Generate a 1024-bit key.  Chilkat RSA supports
    //  key sizes ranging from 512 bits to 4096 bits.
    success = rsa.GenerateKey(1024);
    if (success != true) {
        std::cout << rsa.lastErrorText() << "\r\n";
        return;
    }

    //  Keys are exported in XML format:
    const char *publicKey = rsa.exportPublicKey();
    const char *privateKey = rsa.exportPrivateKey();

    const char *plainText = "Encrypting and decrypting should be easy!";

    //  Start with a new RSA object to demonstrate that all we
    //  need are the keys previously exported:
    CkRsa rsaEncryptor;

    //  Encrypted output is always binary.  In this case, we want
    //  to encode the encrypted bytes in a printable string.
    //  Our choices are "hex", "base64", "url", "quoted-printable".
    rsaEncryptor.put_EncodingMode("hex");

    //  We'll encrypt with the public key and decrypt with the private
    //  key.  It's also possible to do the reverse.
    success = rsaEncryptor.ImportPublicKey(publicKey);

    bool usePrivateKey = false;
    const char *encryptedStr = rsaEncryptor.encryptStringENC(plainText,usePrivateKey);
    std::cout << encryptedStr << "\r\n";

    //  Now decrypt:
    CkRsa rsaDecryptor;

    rsaDecryptor.put_EncodingMode("hex");
    success = rsaDecryptor.ImportPrivateKey(privateKey);

    usePrivateKey = true;
    const char *decryptedStr = rsaDecryptor.decryptStringENC(encryptedStr,usePrivateKey);

    std::cout << decryptedStr << "\r\n";

    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值