Sample code for 30+ languages & platforms
C++

Convert Let's Encrypt PEM Files to a PFX

See more PFX/P12 Examples

Demonstrates how to convert the .pem files provided by Let's Encrypt to a single PFX.

Chilkat C++ Downloads

C++
#include <CkStringBuilder.h>
#include <CkPfx.h>

void ChilkatSample(void)
    {
    bool success = false;

    // This example assumes the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    // Let's Encrypt provides four .pem files
    // 1. fullchain.pem
    // 2. privkey.pem
    // 3. cert.pem
    // 4. chain.pem

    // The cert.pem and chain.pem are redundant. 
    // The fullchain.pem is composed of the cert.pem and chain.pem.

    // To convert the PEM's to a single .pfx, we don't need the redundant data.
    // The privkey.pem and fullchain.pem provide the required data.
    // We can ignore cert.pem and chain.pem (because those certs are already found in fullchain.pem).

    // We need a single .pem file that contains both the private key, the cert,
    // and the certs in the chain of authentication.
    // Let's combine priveky.pem and fullchain.pem into a single .pem

    CkStringBuilder sbPem;
    success = sbPem.LoadFile("qa_data/pem/lets_encrypt/privkey.pem","utf-8");
    if (success == false) {
        std::cout << "Failed to load privkey.pem" << "\r\n";
        return;
    }

    // To be safe, append a blank line..
    sbPem.AppendLine("",false);

    CkStringBuilder sbFullChainPem;
    success = sbFullChainPem.LoadFile("qa_data/pem/lets_encrypt/fullchain.pem","utf-8");
    if (success == false) {
        std::cout << "Failed to load fullchain.pem" << "\r\n";
        return;
    }

    // Append the full cert chain PEM to the private key PEM.
    sbPem.AppendSb(sbFullChainPem);

    // Load the combined PEM into a Chilkat PFX object.
    CkPfx pfx;
    success = pfx.LoadPem(sbPem.getAsString(),"no password required");
    if (success == false) {
        std::cout << pfx.lastErrorText() << "\r\n";
        return;
    }

    // Write the PFX w/ a password.
    const char *pfxPassword = "secret";
    success = pfx.ToFile(pfxPassword,"qa_output/sample.pfx");
    if (success == false) {
        std::cout << pfx.lastErrorText() << "\r\n";
        return;
    }

    std::cout << "Success!" << "\r\n";
    }