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
(Unicode C++) List Keys in a Microsoft Storage ProviderDemonstrates how to list the keys found in a Microsoft CNG Storage Provider, or a Legacy CryptoAPI Storage Provider. Important: This example requires Chilkat v9.5.0.83 or greater.
#include <CkKeyContainerW.h> #include <CkJsonObjectW.h> void ChilkatSample(void) { // This example requires Chilkat v9.5.0.83 or greater. CkKeyContainerW keyCon; CkJsonObjectW json; json.put_EmitCompact(false); bool success = keyCon.GetKeys(L"Microsoft Software Key Storage Provider",json); if (success != true) { wprintf(L"%s\n",keyCon.lastErrorText()); return; } wprintf(L"%s\n",json.emit()); // Sample JSON returned by GetKeys // If the storage provider is CNG, then each key has an "algId". // If the storage provider is legacy CryptoAPI, then each key has a "provType" (see below) // If the storage provider is CNG: // { // "storageProvider": "Microsoft Software Key Storage Provider", // "key": [ // { // "name": "cn=Chilkat Admin,ou=Persona Not Verified,ou=For Test Purposes Only Decryption Key", // "machineKey": false, // "algId": "ECDH_P384" // }, // { // "name": "CD1CC265-0DA0-4230-8419-CB6F808FE688", // "machineKey": false, // "algId": "SP800_108_CTR_HMAC" // }, // { // "name": "{FF14487C-0AED-471E-8FAD-4BF757C2195C}", // "machineKey": false, // "algId": "ECDH_P256" // }, // { // "name": "{869FD9A6-D815-44FD-A916-4D4A708CD949}", // "machineKey": false, // "algId": "ECDH_P256" // }, // { // "name": "D530ECA9-FF5A-4A6A-AAB3-6EC1870F2CC3", // "machineKey": false, // "algId": "SP800_108_CTR_HMAC" // }, // { // "name": "{F524771E-93C0-4D56-8DE7-2FE3CB5BD837}", // "machineKey": false, // "algId": "RSA" // }, // { // "name": "Microsoft Connected Devices Platform device certificate", // "machineKey": false, // "algId": "ECDSA_P256" // } // ] // } // If the storage provider is legacy CryptoAPI: // { // "storageProvider": "Microsoft Base Cryptographic Provider v1.0", // "key": [ // { // "name": "{48D7FF88-A52E-41E2-9EBD-0CC7E880DC65}", // "machineKey": false, // "provType": "PROV_RSA_FULL" // }, // { // "name": "{CBF7A33A-F9CF-4C30-8A06-94A5C7981058}", // "machineKey": false, // "provType": "PROV_RSA_FULL" // } // ] // } // Use this online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON const wchar_t *name = 0; bool machineKey; const wchar_t *algId = 0; const wchar_t *provType = 0; const wchar_t *storageProvider = json.stringOf(L"storageProvider"); int i = 0; int count_i = json.SizeOfArray(L"key"); while (i < count_i) { json.put_I(i); name = json.stringOf(L"key[i].name"); machineKey = json.BoolOf(L"key[i].machineKey"); if (json.HasMember(L"key[i].algId") == true) { algId = json.stringOf(L"key[i].algId"); } if (json.HasMember(L"key[i].provType") == true) { provType = json.stringOf(L"key[i].provType"); } i = i + 1; } } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.