Sample code for 30+ languages & platforms
VB.NET

Open Smartcard Certificate Store (or from USB Token)

See more Certificates Examples

Demonstrates how to open the certificate store of the smart card currently in the reader (or the USB token). Iterates over the certs found on the smartcard.

Chilkat VB.NET Downloads

VB.NET
Dim success As Boolean = False

Dim certStore As New Chilkat.CertStore

' Access the certificates on the smart card or USB token via the Chilkat certificate store class.
' Note: Always pass the empty string to OpenSmartcard.

' ---------------------------------------------------------------------------------------------------------
' The following is true only for Chilkat v10.1.1 and earlier:
' Also, the Chilkat CertStore class can only use MS CNG or CryptoAPI.
' Some smartcard/USB token drivers only support PKCS11 or ScMinidriver.
' You may get better results using Chilkat.Cert.LoadFromSmartcard because
' Cert.LoadFromSmartcard can automatically detect and utilize PKCS11, ScMinidriver, CNG, and CryptoAPI.
' ---------------------------------------------------------------------------------------------------------
' Starting in Chilkat versions after v10.1.1, OpenSmartcard also works with
' Apple Keychain and PKCS11 drivers on Windows, Linux, and MacOS.
' ---------------------------------------------------------------------------------------------------------

success = certStore.OpenSmartcard("")
If (success = False) Then
    Debug.WriteLine(certStore.LastErrorText)
    Exit Sub
End If

Debug.WriteLine(certStore.LastErrorText)

' Iterate over certificates on the smartcard.
Dim cert As New Chilkat.Cert
Dim i As Integer = 0
Dim numCerts As Integer = certStore.NumCertificates
Debug.WriteLine("numCerts = " & numCerts)

While (i < numCerts)
    certStore.GetCert(i,cert)
    Debug.WriteLine(cert.SubjectCN)
    Debug.WriteLine(cert.SerialNumber)
    If (cert.IsRsa() = True) Then
        Debug.WriteLine("key type is RSA")
    End If

    If (cert.IsEcdsa() = True) Then
        Debug.WriteLine("key type is ECDSA")
    End If

    Debug.WriteLine("has private key: " & cert.HasPrivateKey())
    Debug.WriteLine("----")
    i = i + 1
End While