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
(PureBasic) Get a Certificate's Key SizeDemonstrates how to get the RSA key size of a certificate (for example, 1024-bit, 2048-bit, etc.)
IncludeFile "CkBinData.pb" IncludeFile "CkCert.pb" IncludeFile "CkStringBuilder.pb" IncludeFile "CkXml.pb" IncludeFile "CkPublicKey.pb" Procedure ChilkatExample() ; For this example, I have a certificate in raw base64 format (not PEM), ; that looks like this: "MIIGkDCCBHigAwIBAgIUMDA ... s/iqLsLA==" sbCertBase64.i = CkStringBuilder::ckCreate() If sbCertBase64.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success.i = CkStringBuilder::ckLoadFile(sbCertBase64,"qa_data/certs/base64Cert.txt","utf-8") cert.i = CkCert::ckCreate() If cert.i = 0 Debug "Failed to create object." ProcedureReturn EndIf success = CkCert::ckLoadFromBase64(cert,CkStringBuilder::ckGetAsString(sbCertBase64)) If success <> 1 Debug CkCert::ckLastErrorText(cert) CkStringBuilder::ckDispose(sbCertBase64) CkCert::ckDispose(cert) ProcedureReturn EndIf ; Get the public key. pubKey.i = CkCert::ckExportPublicKey(cert) If CkCert::ckLastMethodSuccess(cert) <> 1 Debug CkCert::ckLastErrorText(cert) CkStringBuilder::ckDispose(sbCertBase64) CkCert::ckDispose(cert) ProcedureReturn EndIf ; In Chilkat version v9.5.0.67, the KeySize property was added. numBits.i = CkPublicKey::ckKeySize(pubKey) Debug "Number of bits = " + Str(numBits) ; If using an older version of Chilkat, the key size can be obtained like this: xml.i = CkXml::ckCreate() If xml.i = 0 Debug "Failed to create object." ProcedureReturn EndIf CkXml::ckLoadXml(xml,CkPublicKey::ckGetXml(pubKey)) binDat.i = CkBinData::ckCreate() If binDat.i = 0 Debug "Failed to create object." ProcedureReturn EndIf CkBinData::ckAppendEncoded(binDat,CkXml::ckGetChildContent(xml,"Modulus"),"base64") numBits = 8 * CkBinData::ckNumBytes(binDat) Debug "Number of bits = " + Str(numBits) CkPublicKey::ckDispose(pubKey) CkStringBuilder::ckDispose(sbCertBase64) CkCert::ckDispose(cert) CkXml::ckDispose(xml) CkBinData::ckDispose(binDat) ProcedureReturn EndProcedure |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.