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++) AddDetachedSignaturePkDemonstrates how to add a detached signature using a certifcate and it's corresponding private key. The easiest way of doing it is when both the certificate and private key are contained together within a PFX (.pfx or .p12) file. This example demonstrates how to use the certificate and its corresponding private key when they are stored in separate files -- a .cer for the certificate, and a .pem for the private key.
#include <CkMimeW.h> #include <CkCertW.h> #include <CkPrivateKeyW.h> void ChilkatSample(void) { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkMimeW mime; // Load the certificate from a .cer file. CkCertW cert; bool success = cert.LoadFromFile(L"aaworkarea/myCert.cer"); if (success == false) { wprintf(L"%s\n",cert.lastErrorText()); return; } // Load the private key from an encrypted PEM file. // (A private key can be loaded from other file formats also..) CkPrivateKeyW privKey; success = privKey.LoadEncryptedPemFile(L"aaworkarea/myPrivateKey.pem",L"myPassword"); if (success == false) { wprintf(L"%s\n",privKey.lastErrorText()); return; } success = mime.SetBodyFromPlainText(L"This is the plain-text MIME body."); // Sign the MIME (adds a PKCS7 detached signature) success = mime.AddDetachedSignaturePk(cert,privKey); if (success == false) { wprintf(L"%s\n",mime.lastErrorText()); return; } // Save the S/MIME to a file. success = mime.SaveMime(L"aaworkarea/signedMime.txt"); if (success == false) { wprintf(L"%s\n",mime.lastErrorText()); return; } wprintf(L"success!\n"); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.