Swift
Swift
PC/SC Find Inserted Smart Cards
See more SCard Examples
Get detailed information about each reader including whether or not a smart card is currently inserted in the reader. (Also includes USB tokens.)Note: This functionality was introduced in Chilkat v9.5.0.87.
Chilkat Swift Downloads
func chilkatTest() {
var success: Bool = false
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
let scard = CkoSCard()!
// First establish a context to the PC/SC Resource Manager
success = scard.establishContext(scope: "user")
if success == false {
print("\(scard.lastErrorText!)")
return
}
// Get JSON containing information about the smartcards currently inserted into readers.
// This also includes information about USB security tokens.
let json = CkoJsonObject()!
success = scard.findSmartcards(json: json)
if success == false {
print("\(scard.lastErrorText!)")
return
}
json.emitCompact = false
print("\(json.emit()!)")
// Here is sample output:
// See below for sample code to parse the JSON.
// You can see which readers have a card inserted by the "state".
// If the state contains "present", then a card is inserted into the reader.
// (USB tokens will typically always have a state containing "present")
// Also, the ATR of the card inserted into the reader is indicated by "atr".
// {
// "reader": [
// {
// "name": "Alcor Micro USB Smart Card Reader 0",
// "state": "present,inuse",
// "vendorName": "Alcor Micro",
// "systemName": "Alcor Micro USB Smart Card Reader 0",
// "card": {
// "atr": "3B7F96000080318065B0855956FB120FFE829000",
// "windows": {
// "miniDriver": "AxaltoCM.dll",
// "cryptoProvider": "Microsoft Base Smart Card Crypto Provider",
// "keyStorageProvider": "Microsoft Smart Card Key Storage Provider"
// }
// }
// },
// {
// "name": "FS USB Token 0",
// "state": "present,inuse",
// "vendorName": "FS",
// "serialNumber": "3F",
// "systemName": "FS USB Token 0",
// "card": {
// "atr": "3B9F958131FE9F006646530534002571DF000000000012",
// "windows": {
// "miniDriver": "eps2003csp11",
// "cryptoProvider": "Microsoft Base Smart Card Crypto Provider",
// "keyStorageProvider": "Microsoft Smart Card Key Storage Provider"
// }
// }
// },
// {
// "name": "FT Java Token 0",
// "state": "present",
// "vendorName": "FT",
// "serialNumber": "3F",
// "systemName": "FT Java Token 0",
// "card": {
// "atr": "3BFC180000813180459067464A00642D70C172FEE0FE",
// "windows": {
// "miniDriver": "tagliov70px.dll",
// "cryptoProvider": "Microsoft Base Smart Card Crypto Provider",
// "keyStorageProvider": "Microsoft Smart Card Key Storage Provider"
// }
// }
// },
// {
// "name": "SCM Microsystems Inc. SCR33x USB Smart Card Reader 0",
// "state": "present",
// "vendorName": "SCM Microsystems Inc.",
// "serialNumber": "333130303330",
// "systemName": "SCM Microsystems Inc. SCR33x USB Smart Card Reader 0",
// "card": {
// "atr": "3BFC180000813180459067464A00641606F2727E00E0",
// "windows": {
// "miniDriver": "tagliov70px.dll",
// "cryptoProvider": "Microsoft Base Smart Card Crypto Provider",
// "keyStorageProvider": "Microsoft Smart Card Key Storage Provider"
// }
// }
// },
// {
// "name": "Yubico YubiKey OTP+FIDO+CCID 0",
// "state": "present",
// "vendorName": "Yubico",
// "serialNumber": "3F",
// "systemName": "Yubico YubiKey OTP+FIDO+CCID 0",
// "card": {
// "atr": "3BFD1300008131FE158073C021C057597562694B657940",
// "windows": {
// "miniDriver": "msclmd.dll",
// "cryptoProvider": "Microsoft Base Smart Card Crypto Provider",
// "keyStorageProvider": "Microsoft Smart Card Key Storage Provider"
// }
// }
// }
// ]
// }
// Use this online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
var name: String?
var state: String?
var vendorName: String?
var systemName: String?
var cardAtr: String?
var cardWindowsMiniDriver: String?
var cardWindowsCryptoProvider: String?
var cardWindowsKeyStorageProvider: String?
var serialNumber: String?
var i: Int = 0
var count_i: Int = json.size(ofArray: "reader").intValue
while i < count_i {
json.i = i
name = json.string(of: "reader[i].name")
state = json.string(of: "reader[i].state")
vendorName = json.string(of: "reader[i].vendorName")
systemName = json.string(of: "reader[i].systemName")
cardAtr = json.string(of: "reader[i].card.atr")
cardWindowsMiniDriver = json.string(of: "reader[i].card.windows.miniDriver")
cardWindowsCryptoProvider = json.string(of: "reader[i].card.windows.cryptoProvider")
cardWindowsKeyStorageProvider = json.string(of: "reader[i].card.windows.keyStorageProvider")
serialNumber = json.string(of: "reader[i].serialNumber")
i = i + 1
}
// Applications should always release the context when finished.
success = scard.releaseContext()
if success == false {
print("\(scard.lastErrorText!)")
}
}