C++
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
#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";
}