Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(C) Generate RSA Key and Export to Encrypted PEMC sample showing how to generate an RSA key and export to encrypted PEM.
#include <C_CkRsa.h> #include <C_CkPrivateKey.h> void ChilkatSample(void) { HCkRsa rsa; BOOL success; const char *keyXml; HCkPrivateKey privKey; const char *strEncPem; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. rsa = CkRsa_Create(); // Generate a 1024-bit key. Chilkat RSA supports // key sizes ranging from 512 bits to 4096 bits. success = CkRsa_GenerateKey(rsa,1024); if (success != TRUE) { printf("%s\n",CkRsa_lastErrorText(rsa)); CkRsa_Dispose(rsa); return; } // Get the private key as unencrypted XML: keyXml = CkRsa_exportPrivateKey(rsa); printf("%s\n",keyXml); // To encrypt the key -- meaning to get the key in // an encrypted PEM format -- load it into a PrivateKey object, // and then export to encrypted PEM: privKey = CkPrivateKey_Create(); success = CkPrivateKey_LoadXml(privKey,keyXml); if (success != TRUE) { printf("%s\n",CkPrivateKey_lastErrorText(privKey)); CkRsa_Dispose(rsa); CkPrivateKey_Dispose(privKey); return; } strEncPem = CkPrivateKey_getPkcs8EncryptedPem(privKey,"myPassword"); // You now have the private key in an encrypted format, // which may be (for example) saved to a database CkRsa_Dispose(rsa); CkPrivateKey_Dispose(privKey); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.