Sample code for 30+ languages & platforms
PureBasic

How to Parse a X.509 Certificate and Extract its Public Key

See more Certificates Examples

Demonstrates how to load an X.509 certificate and extract the public key. Chilkat supports many certificate encodings:
  • DER (binary) encoded certificates (.crt/.cer)
  • PEM (BASE64) encoded certificates (.pem)
  • Load Certificates Directly from Windows Certificate Stores
  • PFX/PKCS12 (.pfx/.p12)
  • Java KeyStore (.jks)
  • Cryptographic Message Syntax Standard - PKCS #7 Certificates (.P7B)

Chilkat PureBasic Downloads

PureBasic
IncludeFile "CkPublicKey.pb"
IncludeFile "CkCert.pb"

Procedure ChilkatExample()

    success.i = 0

    cert.i = CkCert::ckCreate()
    If cert.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    ; Load a DER (binary) encoded certificate.
    ; To load from a .pem or .p7b, or any other file format that contains
    ; just one certificate, call LoadFromFile in exactly the same way.
    ; The LoadFromFile method automatically detects the format and loads the certificate.
    success = CkCert::ckLoadFromFile(cert,"qa_data/certs/testCert.cer")
    If success = 0
        Debug CkCert::ckLastErrorText(cert)
        CkCert::ckDispose(cert)
        ProcedureReturn
    EndIf

    ; Get the public key:
    pubKey.i = CkPublicKey::ckCreate()
    If pubKey.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    CkCert::ckGetPublicKey(cert,pubKey)

    ; Examine the key type.
    ; A PublicKey object can contain an RSA, ECC, or DSA public key.
    ; The KeyType property will contain "rsa", "ecc", or "dsa".
    Debug "key type = " + CkPublicKey::ckKeyType(pubKey)


    CkCert::ckDispose(cert)
    CkPublicKey::ckDispose(pubKey)


    ProcedureReturn
EndProcedure