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
(Unicode C++) Get an EC Key in Raw Hex FormatDemonstrates how to get the private and public key parts of an EC (ECDSA) key in lowercase hex formmat. Note: This example requires Chilkat v9.5.0.83 or greater.
#include <CkPrivateKeyW.h> #include <CkStringBuilderW.h> void ChilkatSample(void) { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // Load an EC key from some format.. CkPrivateKeyW privKey; // This loads an ECDSA key from an unencrypted PEM file (no password required). bool success = privKey.LoadAnyFormatFile(L"qa_data/ecc/openssl_ecc_privKey.pem",L""); if (success == false) { wprintf(L"%s\n",privKey.lastErrorText()); return; } // The key type should be "ecc" to indicate an EC key. wprintf(L"key type = %s\n",privKey.keyType()); // What is the size of the private key in bits? wprintf(L"size in bits = %d\n",privKey.get_BitLength()); // Get the private and public EC key parts in raw hex format: CkStringBuilderW sbPubKeyHex; const wchar_t *privKeyHex = privKey.getRawHex(sbPubKeyHex); // If the private key size in bits is 256, then we should have a 32-byte key (a 64 character hex string). wprintf(L"private key = %s\n",privKeyHex); // The public key is composed of the "x" and "y" parts, and is composed like this: 04||HEX(x)||HEX(y) wprintf(L"public key = %s\n",sbPubKeyHex.getAsString()); // Sample output: // key type = ecc // size in bits = 256 // private key = ced36f2ba3332be439f79143d69937fc52494cd38e45243c3ea05db183919f1b // public key = 045b4edcd501831740895f5907feabb71587076a6314d9d5141f9f8c33a478b8ce08b8dfd2a091eb6355803d7e729876c790bc0b176f2015f3bb103813753f676a } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.