DataFlex
DataFlex
Load Certificate from Smart Card by Key Usage
See more Certificates Examples
You may have a smartcard or USB token that contains only 2 certificates, one for signing, and one for authentication, and you wish to load the certificate for signing. This example demonstrates how to load the 1st certificate found on a smartcard that matches the intended key usage.Chilkat DataFlex Downloads
Use ChilkatAx-win32.pkg
Procedure Test
Boolean iSuccess
Handle hoCert
String sTemp1
String sTemp2
Move False To iSuccess
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
Get Create (RefClass(cComChilkatCert)) To hoCert
If (Not(IsComObjectCreated(hoCert))) Begin
Send CreateComObject of hoCert
End
// If you know the smart card PIN, set it prior to loading from the smartcard/USB token.
Set ComSmartCardPin Of hoCert To "12345678"
// To load a certificate matching an intended key usage, specify the type of usage as shown below.
//
// The possible key usage keywords are:
//
// digitalsignature
// Use when the public key is used with a digital signature mechanism to support security services other than non-repudiation, certificate signing, or CRL signing.
// A digital signature is often used for entity authentication and data origin authentication with integrity.
// nonrepudiation
// When a digital certificate's key usage includes "nonrepudiation," it implies that the certificate and its associated private key can be used to
// create digital signatures that provide proof of the origin and integrity of the signed data, and the signer cannot later deny having signed the data.
// Other less common usages:
// certificatesigning
// keyencipherment
// dataencipherment
// crlsigning
// secureemail
// serverauthentication
// clientauthentication
// codesigning
// timestamping
Get ComLoadFromSmartcard Of hoCert "keyusage=nonrepudiation" To iSuccess
If (iSuccess = False) Begin
Get ComLastErrorText Of hoCert To sTemp1
Showln sTemp1
Showln "Certificate not loaded."
Procedure_Return
End
Get ComSubjectDN Of hoCert To sTemp1
Get ComSerialNumber Of hoCert To sTemp2
Showln "Found: " sTemp1 " serial=" sTemp2
End_Procedure