Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) PC/SC Find Inserted Smart CardsSee more SCard ExamplesGet 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.
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. DECLARE @scard int -- Use "Chilkat_9_5_0.SCard" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.SCard', @scard OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END -- First establish a context to the PC/SC Resource Manager DECLARE @success int EXEC sp_OAMethod @scard, 'EstablishContext', @success OUT, 'user' IF @success = 0 BEGIN EXEC sp_OAGetProperty @scard, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @scard RETURN END -- Get JSON containing information about the smartcards currently inserted into readers. -- This also includes information about USB security tokens. DECLARE @json int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT EXEC sp_OAMethod @scard, 'FindSmartcards', @success OUT, @json IF @success = 0 BEGIN EXEC sp_OAGetProperty @scard, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @scard EXEC @hr = sp_OADestroy @json RETURN END EXEC sp_OASetProperty @json, 'EmitCompact', 0 EXEC sp_OAMethod @json, 'Emit', @sTmp0 OUT PRINT @sTmp0 -- 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 DECLARE @name nvarchar(4000) DECLARE @state nvarchar(4000) DECLARE @vendorName nvarchar(4000) DECLARE @systemName nvarchar(4000) DECLARE @cardAtr nvarchar(4000) DECLARE @cardWindowsMiniDriver nvarchar(4000) DECLARE @cardWindowsCryptoProvider nvarchar(4000) DECLARE @cardWindowsKeyStorageProvider nvarchar(4000) DECLARE @serialNumber nvarchar(4000) DECLARE @i int SELECT @i = 0 DECLARE @count_i int EXEC sp_OAMethod @json, 'SizeOfArray', @count_i OUT, 'reader' WHILE @i < @count_i BEGIN EXEC sp_OASetProperty @json, 'I', @i EXEC sp_OAMethod @json, 'StringOf', @name OUT, 'reader[i].name' EXEC sp_OAMethod @json, 'StringOf', @state OUT, 'reader[i].state' EXEC sp_OAMethod @json, 'StringOf', @vendorName OUT, 'reader[i].vendorName' EXEC sp_OAMethod @json, 'StringOf', @systemName OUT, 'reader[i].systemName' EXEC sp_OAMethod @json, 'StringOf', @cardAtr OUT, 'reader[i].card.atr' EXEC sp_OAMethod @json, 'StringOf', @cardWindowsMiniDriver OUT, 'reader[i].card.windows.miniDriver' EXEC sp_OAMethod @json, 'StringOf', @cardWindowsCryptoProvider OUT, 'reader[i].card.windows.cryptoProvider' EXEC sp_OAMethod @json, 'StringOf', @cardWindowsKeyStorageProvider OUT, 'reader[i].card.windows.keyStorageProvider' EXEC sp_OAMethod @json, 'StringOf', @serialNumber OUT, 'reader[i].serialNumber' SELECT @i = @i + 1 END -- Applications should always release the context when finished. EXEC sp_OAMethod @scard, 'ReleaseContext', @success OUT IF @success = 0 BEGIN EXEC sp_OAGetProperty @scard, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 END EXEC @hr = sp_OADestroy @scard EXEC @hr = sp_OADestroy @json END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.