PureBasic
PureBasic
Load Certificate from Smart Card by Serial Number
See more Certificates Examples
This example requires Chilkat v9.5.0.87 or greater. It uses a Windows-only function named LoadFromSmartcard.This example loads a certificate specified by its hexidecimal serial number. The LoadFromSmartcard method will examine the connected smart cards and USB tokens and will find and load the certificate having the specified serial number.
Chilkat PureBasic Downloads
IncludeFile "CkCert.pb"
Procedure ChilkatExample()
success.i = 0
; This example requires the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.
cert.i = CkCert::ckCreate()
If cert.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
; If you know the smart card PIN, set it prior to loading from the smartcard/USB token.
CkCert::setCkSmartCardPin(cert, "12345678")
; To load the certificate specified by its hexidecimal serial number, pass the string "serial=<hexSerialNumber>". For example:
success = CkCert::ckLoadFromSmartcard(cert,"serial=4A1E6ADCF59DB1EFBAAE438D2C52664E40D16A87")
If success = 0
Debug CkCert::ckLastErrorText(cert)
Debug "Certificate not loaded."
CkCert::ckDispose(cert)
ProcedureReturn
EndIf
Debug "Found: " + CkCert::ckSubjectDN(cert) + " serial=" + CkCert::ckSerialNumber(cert)
; Here's another example.
; Note: serial numbers can be of different lengths. The length of the serial number depends on the certificate.
cert2.i = CkCert::ckCreate()
If cert2.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
success = CkCert::ckLoadFromSmartcard(cert2,"serial=66BE58138D761E92BC594A722932657BE26D421F")
If success = 0
Debug CkCert::ckLastErrorText(cert2)
Debug "Certificate not loaded."
CkCert::ckDispose(cert)
CkCert::ckDispose(cert2)
ProcedureReturn
EndIf
Debug "Found: " + CkCert::ckSubjectDN(cert2) + " serial=" + CkCert::ckSerialNumber(cert2)
CkCert::ckDispose(cert)
CkCert::ckDispose(cert2)
ProcedureReturn
EndProcedure