![]() |
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 Base64 Private KeySigns a string using a non-encrypted RSA private key in base64 encoding. Returns the RSA signature as a base64 string.
#include <C_CkPrivateKey.h> #include <C_CkStringBuilder.h> #include <C_CkRsa.h> void ChilkatSample(void) { HCkPrivateKey privKey; BOOL success; HCkStringBuilder sbPem; HCkRsa rsa; const char *strSigned; const char *strOriginal; // This requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. privKey = CkPrivateKey_Create(); sbPem = CkStringBuilder_Create(); CkStringBuilder_AppendLine(sbPem,"-----BEGIN RSA PRIVATE KEY-----",TRUE); CkStringBuilder_AppendLine(sbPem,"MIIC .... j5A==",TRUE); CkStringBuilder_AppendLine(sbPem,"-----END RSA PRIVATE KEY-----",TRUE); success = CkPrivateKey_LoadPem(privKey,CkStringBuilder_getAsString(sbPem)); if (success != TRUE) { printf("%s\n",CkPrivateKey_lastErrorText(privKey)); CkPrivateKey_Dispose(privKey); CkStringBuilder_Dispose(sbPem); return; } rsa = CkRsa_Create(); success = CkRsa_ImportPrivateKeyObj(rsa,privKey); if (success != TRUE) { printf("%s\n",CkRsa_lastErrorText(rsa)); CkPrivateKey_Dispose(privKey); CkStringBuilder_Dispose(sbPem); CkRsa_Dispose(rsa); return; } CkRsa_putEncodingMode(rsa,"base64"); strSigned = CkRsa_openSslSignStringENC(rsa,"12345678"); printf("%s\n",strSigned); strOriginal = CkRsa_openSslVerifyStringENC(rsa,strSigned); printf("%s\n",strOriginal); CkPrivateKey_Dispose(privKey); CkStringBuilder_Dispose(sbPem); CkRsa_Dispose(rsa); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.