Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(C++) Get a Certificate's Key SizeDemonstrates how to get the RSA key size of a certificate (for example, 1024-bit, 2048-bit, etc.)
#include <CkStringBuilder.h> #include <CkCert.h> #include <CkPublicKey.h> #include <CkXml.h> #include <CkBinData.h> void ChilkatSample(void) { // For this example, I have a certificate in raw base64 format (not PEM), // that looks like this: "MIIGkDCCBHigAwIBAgIUMDA ... s/iqLsLA==" CkStringBuilder sbCertBase64; bool success = sbCertBase64.LoadFile("qa_data/certs/base64Cert.txt","utf-8"); CkCert cert; success = cert.LoadFromBase64(sbCertBase64.getAsString()); if (success != true) { std::cout << cert.lastErrorText() << "\r\n"; return; } // Get the public key. CkPublicKey *pubKey = cert.ExportPublicKey(); if (cert.get_LastMethodSuccess() != true) { std::cout << cert.lastErrorText() << "\r\n"; return; } // In Chilkat version v9.5.0.67, the KeySize property was added. int numBits = pubKey->get_KeySize(); std::cout << "Number of bits = " << numBits << "\r\n"; // If using an older version of Chilkat, the key size can be obtained like this: CkXml xml; xml.LoadXml(pubKey->getXml()); CkBinData binDat; binDat.AppendEncoded(xml.getChildContent("Modulus"),"base64"); numBits = 8 * binDat.get_NumBytes(); std::cout << "Number of bits = " << numBits << "\r\n"; delete pubKey; } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.