Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(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 <CkMime.h> #include <CkCert.h> #include <CkPrivateKey.h> void ChilkatSample(void) { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkMime mime; // Load the certificate from a .cer file. CkCert cert; bool success = cert.LoadFromFile("aaworkarea/myCert.cer"); if (success == false) { std::cout << cert.lastErrorText() << "\r\n"; return; } // Load the private key from an encrypted PEM file. // (A private key can be loaded from other file formats also..) CkPrivateKey privKey; success = privKey.LoadEncryptedPemFile("aaworkarea/myPrivateKey.pem","myPassword"); if (success == false) { std::cout << privKey.lastErrorText() << "\r\n"; return; } success = mime.SetBodyFromPlainText("This is the plain-text MIME body."); // Sign the MIME (adds a PKCS7 detached signature) success = mime.AddDetachedSignaturePk(cert,privKey); if (success == false) { std::cout << mime.lastErrorText() << "\r\n"; return; } // Save the S/MIME to a file. success = mime.SaveMime("aaworkarea/signedMime.txt"); if (success == false) { std::cout << mime.lastErrorText() << "\r\n"; return; } std::cout << "success!" << "\r\n"; } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.