Sample code for 30+ languages & platforms
C++

Create PKCS7 Signed File (.p7m)

See more Encryption Examples

Demonstrates how to sign a file to create a .p7m that contains both the file contents and the signature.

Chilkat C++ Downloads

C++
#include <CkCrypt2.h>
#include <CkCertStore.h>
#include <CkJsonObject.h>
#include <CkCert.h>

void ChilkatSample(void)
    {
    bool success = false;

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

    CkCrypt2 crypt;

    CkCertStore certStore;

    // Load a PFX file into a certificate store object.
    success = certStore.LoadPfxFile("myPfx.pfx","pfxPassword");
    if (success != true) {
        std::cout << certStore.lastErrorText() << "\r\n";
        return;
    }

    // Get the certificate by subject common name.
    // This should be the cert within the PFX that also
    // has a private key (also stored within the PFX).
    CkJsonObject jsonCN;
    jsonCN.UpdateString("CN","myCert");
    CkCert cert;
    success = certStore.FindCert(jsonCN,cert);
    if (success == false) {
        std::cout << certStore.lastErrorText() << "\r\n";
        return;
    }

    // Tell the crypt object to use the certificate for signing:
    success = crypt.SetSigningCert(cert);

    // Sign a file, producing a .p7m as output.
    // The input file is unchanged, the test.p7m contains the 
    // contents of the input file and the signature.
    const char *inFile = "test.txt";
    const char *outFile = "testp7m";
    success = crypt.CreateP7M(inFile,outFile);
    if (success != true) {
        std::cout << crypt.lastErrorText() << "\r\n";
        return;
    }

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