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
(C++) Load Certificate from PFX (PKCS#12)Loads a digital certificate (and private key, if available) from a PFX file.(also known as PKCS#12)
#include <CkCert.h> #include <CkPrivateKey.h> void ChilkatSample(void) { CkCert cert; bool success; // Load from the PFX file const char *pfxFilename = "/Users/chilkat/testData/pfx/chilkat_ssl_pwd_is_test.pfx"; const char *pfxPassword = "test"; // A PFX typically contains certificates in the chain of authentication. // The Chilkat cert object will choose the certificate w/ // private key farthest from the root authority cert. // To access all the certificates in a PFX, use the // Chilkat certificate store object instead. success = cert.LoadPfxFile(pfxFilename,pfxPassword); if (success != true) { std::cout << cert.lastErrorText() << "\r\n"; return; } // Get some information about the digital certificate, // then get the private key... // DN = "Distinguished Name" std::cout << "SubjectDN:" << cert.subjectDN() << "\r\n"; std::cout << "Common Name:" << cert.subjectCN() << "\r\n"; std::cout << "Issuer Common Name:" << cert.issuerCN() << "\r\n"; std::cout << "Serial Number:" << cert.serialNumber() << "\r\n"; // Now for the private key... CkPrivateKey *privKey = 0; privKey = cert.ExportPrivateKey(); if (cert.get_LastMethodSuccess() == false) { std::cout << cert.lastErrorText() << "\r\n"; return; } // The private key object may be used in any Chilkat methods // (in other objects/classes) that expect a private key argument. // In this case, save the private key to a PKCS8 Encrypted PEM format file: const char *pemPassword = "secret"; const char *pemPath = "/Users/chilkat/testData/pem/chilkat_privKey.pem"; success = privKey->SavePkcs8EncryptedPemFile(pemPassword,pemPath); if (success != true) { std::cout << privKey->lastErrorText() << "\r\n"; delete privKey; return; } delete privKey; std::cout << "Private key saved to PKCS8 Encrypted PEM..." << "\r\n"; } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.