PureBasic
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
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