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++) Load Signed and/or Encrypted Email and Unwrap Security LayersThe LoadEml method loads an email (.eml file containing the MIME of an email) and automatically unwraps the digital signature and encryption security layers. A program can then examine the properties of the email object to see what was unwrapped.
#include <CkEmail.h> void ChilkatSample(void) { CkEmail email; // Provide PFX/.p12 files for any certs+keys needed for decryption. // Signature verification does not need anything extra. // (Also, Chilkat will automatically find and use pre-installed certs + private keys needed for decryption // on a Windows system.) bool success = email.AddPfxSourceFile("/pfxFiles/certs_and_keys_1.pfx","pfxPassword1"); if (success != true) { std::cout << email.lastErrorText() << "\r\n"; return; } success = email.AddPfxSourceFile("/pfxFiles/certs_and_keys_2.pfx","pfxPassword2"); if (success != true) { std::cout << email.lastErrorText() << "\r\n"; return; } // ... // Load a potentially signed and/or encrypted email. success = email.LoadEml("someDir/someEmail.eml"); // If the email was signed and/or encrypted, it was "unwrapped", i.e. // the email is already decrypted and in a state as if it were never signed or encrypted. // You may check to see if the email was received encrypted or signed, and if so, // whether it was successfully unwrapped and who signed or encrypted it: if (email.get_ReceivedEncrypted() == true) { std::cout << "This email was encrypted." << "\r\n"; if (email.get_Decrypted() == true) { std::cout << "This email was successfully decrypted. It was encrypted by:" << "\r\n"; std::cout << email.encryptedBy() << "\r\n"; } else { std::cout << "This email was not decrypted." << "\r\n"; } } if (email.get_ReceivedSigned() == true) { std::cout << "This email was signed." << "\r\n"; if (email.get_SignaturesValid() == true) { std::cout << "The signature was verified. It was signed by:" << "\r\n"; std::cout << email.signedBy() << "\r\n"; } else { std::cout << "The signature verification failed." << "\r\n"; } } // At this point, the contents of the email, including attachments, can be accessed normally.. } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.