Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PureBasic) PKCS11 Login / LogoutSee more PKCS11 ExamplesSample code showing how to login and logout of a PKCS11 session. A session becomes authenticated when Login is called, and returns to the unauthenticated state when Logout is called. A smart card's PIN is passed to the Login method. Note: This example requires Chilkat v9.5.0.88 or later.
IncludeFile "CkPkcs11.pb" Procedure ChilkatExample() ; This example requires the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. ; Note: Chilkat's PKCS11 implementation runs on Windows, Linux, Mac OS X, and other supported operating systems. pkcs11.i = CkPkcs11::ckCreate() If pkcs11.i = 0 Debug "Failed to create object." ProcedureReturn EndIf ; Set your shared lib path -- either a full path to the DLL, .so, or .dylib, ; or just the filename if the driver is in a location that can be automatically found. (Such as in C:\Windows\System32) CkPkcs11::setCkSharedLibPath(pkcs11, "aetpkss1.dll") success.i = CkPkcs11::ckInitialize(pkcs11) If success = 0 Debug CkPkcs11::ckLastErrorText(pkcs11) CkPkcs11::ckDispose(pkcs11) ProcedureReturn EndIf ; Pass -1 for the slotID to open a session on the first non-empty slot. slotID.i = -1 ; Open a session. readWrite.i = 1 success = CkPkcs11::ckOpenSession(pkcs11,slotID,readWrite) If success = 0 Debug CkPkcs11::ckLastErrorText(pkcs11) CkPkcs11::ckDispose(pkcs11) ProcedureReturn EndIf ; Make it an authenticated session by calling Login. ; The smart card PIN is passed to the Login method. ; The user type can be one of three choices: ; 0 - Security Officer ; 1 - Normal User ; 2 - Context Specific. ; You'll likely always login as the Normal User. userType.i = 1 pin.s = "0000" success = CkPkcs11::ckLogin(pkcs11,userType,pin) If success = 0 Debug CkPkcs11::ckLastErrorText(pkcs11) success = CkPkcs11::ckCloseSession(pkcs11) CkPkcs11::ckDispose(pkcs11) ProcedureReturn EndIf ; Do what is needed with the authenticated session... ; ... ; ... ; Revert to an unauthenticated session by calling Logout. success = CkPkcs11::ckLogout(pkcs11) If success = 0 Debug CkPkcs11::ckLastErrorText(pkcs11) success = CkPkcs11::ckCloseSession(pkcs11) CkPkcs11::ckDispose(pkcs11) ProcedureReturn EndIf ; When finished, close the session. ; It is important to close the session (memory leaks will occur if the session is not properly closed). success = CkPkcs11::ckCloseSession(pkcs11) If success = 0 Debug CkPkcs11::ckLastErrorText(pkcs11) CkPkcs11::ckDispose(pkcs11) ProcedureReturn EndIf Debug "PKCS11 Login and Logout successfully demonstrated." CkPkcs11::ckDispose(pkcs11) ProcedureReturn EndProcedure |
© 2000-2023 Chilkat Software, Inc. All Rights Reserved.