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) RSA Sign Using Private Key from .pfx/.p12 to Base64 SignatureSee more RSA ExamplesDemonstrates how to RSA sign something using a private key loaded from a .pfx/.p12. The RSA signature is returned in Base64 encoded format.
#include <C_CkRsa.h> #include <C_CkPfx.h> #include <C_CkPrivateKey.h> void ChilkatSample(void) { HCkRsa rsa; HCkPfx pfx; BOOL success; HCkPrivateKey privKey; const char *strData; const char *base64Sig; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. rsa = CkRsa_Create(); // Load the .pfx/.p12 pfx = CkPfx_Create(); success = CkPfx_LoadPfxFile(pfx,"qa_data/pfx/myKey.p12","myPassword"); if (success != TRUE) { printf("%s\n",CkPfx_lastErrorText(pfx)); CkRsa_Dispose(rsa); CkPfx_Dispose(pfx); return; } // Get the default private key. privKey = CkPfx_GetPrivateKey(pfx,0); if (CkPfx_getLastMethodSuccess(pfx) != TRUE) { printf("%s\n",CkPfx_lastErrorText(pfx)); CkRsa_Dispose(rsa); CkPfx_Dispose(pfx); return; } // Import the private key into the RSA component: success = CkRsa_ImportPrivateKeyObj(rsa,privKey); if (success != TRUE) { printf("%s\n",CkRsa_lastErrorText(rsa)); CkPrivateKey_Dispose(privKey); CkRsa_Dispose(rsa); CkPfx_Dispose(pfx); return; } CkPrivateKey_Dispose(privKey); // Get the signature in base64 CkRsa_putEncodingMode(rsa,"base64"); strData = "This is the string to be signed."; // Sign the string using the sha256 hash algorithm. // Other valid choices are "sha384", "sha512", "sha-1", "md2" and "md5". base64Sig = CkRsa_signStringENC(rsa,strData,"sha256"); printf("%s\n",base64Sig); printf("Success!\n"); CkRsa_Dispose(rsa); CkPfx_Dispose(pfx); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.