Sample code for 30+ languages & platforms
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

DataFlex
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