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
(Unicode C) Duplicate openssl pkcs12 –export –in certfile.cer –inkey certfile.key –out certfile.pfxHow to create a PKCS12 (.p12 or .pfx) from a certificate file and private key file: Demonstrates how to duplicate this OpenSSL command: Duplicate openssl pkcs12 –export –in certfile.cer –inkey certfile.key –out certfile.pfx
#include <C_CkPrivateKeyW.h> #include <C_CkCertW.h> #include <C_CkCertChainW.h> #include <C_CkPfxW.h> void ChilkatSample(void) { BOOL success; HCkPrivateKeyW pkey; HCkCertW cert; HCkCertChainW certChain; HCkPfxW pfx; const wchar_t *password; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. pkey = CkPrivateKeyW_Create(); // Load the private key from the file. success = CkPrivateKeyW_LoadAnyFormatFile(pkey,L"certFile.key",L""); if (success != TRUE) { wprintf(L"%s\n",CkPrivateKeyW_lastErrorText(pkey)); CkPrivateKeyW_Dispose(pkey); return; } cert = CkCertW_Create(); // The LoadFromFile method auto-recognizes the format... success = CkCertW_LoadFromFile(cert,L"certfile.cer"); if (success != TRUE) { wprintf(L"%s\n",CkCertW_lastErrorText(cert)); CkPrivateKeyW_Dispose(pkey); CkCertW_Dispose(cert); return; } // We'll need a cert chain object to create the PKCS12, so get it // from the cert. certChain = CkCertW_GetCertChain(cert); if (!CkCertW_getLastMethodSuccess(cert)) { wprintf(L"%s\n",CkCertW_lastErrorText(cert)); CkPrivateKeyW_Dispose(pkey); CkCertW_Dispose(cert); return; } // Create the PFX object, add the cert and private key, and write to a .pfx file. pfx = CkPfxW_Create(); // The cert(s) are automatically added in the call to AddPrivateKey success = CkPfxW_AddPrivateKey(pfx,pkey,certChain); if (success != TRUE) { wprintf(L"%s\n",CkPfxW_lastErrorText(pfx)); CkPrivateKeyW_Dispose(pkey); CkCertW_Dispose(cert); CkPfxW_Dispose(pfx); return; } // Write the .pfx to a file. password = L"myPassword"; success = CkPfxW_ToFile(pfx,password,L"certfile.pfx"); if (success != TRUE) { wprintf(L"%s\n",CkPfxW_lastErrorText(pfx)); CkPrivateKeyW_Dispose(pkey); CkCertW_Dispose(cert); CkPfxW_Dispose(pfx); return; } wprintf(L"Success.\n"); CkPrivateKeyW_Dispose(pkey); CkCertW_Dispose(cert); CkPfxW_Dispose(pfx); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.