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
(C++) Load Particular CA Certs into a Java KeyStoreOpens a PEM file containing many CA root certificates, and creates a Java keystore containing a subset of the certificates.
#include <CkJavaKeyStore.h> #include <CkTrustedRoots.h> #include <CkStringBuilder.h> #include <CkCert.h> void ChilkatSample(void) { // This requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkJavaKeyStore jks; CkTrustedRoots troots; // Load certificates from a file. bool success = troots.LoadCaCertsPem("qa_data/curl_cacert.pem"); if (success != true) { std::cout << troots.lastErrorText() << "\r\n"; return; } CkStringBuilder sbDn; CkStringBuilder sbAlias; bool caseSensitive = false; int i = 0; int numCerts = troots.get_NumCerts(); int numAdded = 0; while ((i < numCerts)) { CkCert *cacert = troots.GetCert(i); sbDn.Clear(); sbDn.Append(cacert->subjectDN()); if (sbDn.Contains("Entrust.net",caseSensitive) == true) { std::cout << cacert->subjectDN() << "\r\n"; // The alias is an arbitrary unique string for each cert in the JKS. sbAlias.Clear(); sbAlias.Append("cacert_"); sbAlias.AppendInt(i + 1); jks.AddTrustedCert(*cacert,sbAlias.getAsString()); numAdded = numAdded + 1; } delete cacert; i = i + 1; } // Verify the number of certs in the JKS equals the number we added. int numJksCerts = jks.get_NumTrustedCerts(); std::cout << "NumTrustedCerts = " << numJksCerts << "\r\n"; if (numJksCerts != numAdded) { std::cout << "Something is amiss!" << "\r\n"; return; } // Save the JKS. success = jks.ToFile("myPassword","qa_data/jks/entrust_caCerts.jks"); if (success != true) { std::cout << jks.lastErrorText() << "\r\n"; return; } std::cout << "Success." << "\r\n"; // The output of this program when tested was: // C=US, O=Entrust.net, OU=www.entrust.net/CPS incorp. by ref. (limits liab.), OU=(c) 1999 Entrust.net Limited, CN=Entrust.net Secure Server Certification Authority // O=Entrust.net, OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.), OU=(c) 1999 Entrust.net Limited, CN=Entrust.net Certification Authority (2048) // C=US, O="Entrust, Inc.", OU=www.entrust.net/CPS is incorporated by reference, OU="(c) 2006 Entrust, Inc.", CN=Entrust Root Certification Authority // NumTrustedCerts = 3 // Success. } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.