Unicode C
Unicode C
Encrypt MIME using RSAES-OAEP with SHA256 and AES-128 content encryption
See more MIME Examples
Demonstrates how to encrypt MIME using RSAES-OAEP with SHA256 and AES-128 content encryption.Note: This example requires Chilkat v9.5.0.67 or greater.
Chilkat Unicode C Downloads
#include <C_CkMimeW.h>
#include <C_CkStringBuilderW.h>
#include <C_CkCertW.h>
void ChilkatSample(void)
{
BOOL success;
HCkMimeW mime;
HCkMimeW part0;
HCkMimeW part1;
HCkStringBuilderW sbMime;
HCkCertW cert;
success = FALSE;
// This requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
mime = CkMimeW_Create();
// Create a MIME message to encrypt.
CkMimeW_NewMultipartMixed(mime);
CkMimeW_AddHeaderField(mime,L"someHeader1",L"Some value 1");
CkMimeW_AddHeaderField(mime,L"someHeader2",L"Some value 2");
part0 = CkMimeW_Create();
CkMimeW_AddHeaderField(part0,L"hdrA",L"Some value A");
CkMimeW_AddHeaderField(part0,L"hdrB",L"Some value B");
CkMimeW_putContentType(part0,L"text/plain");
CkMimeW_SetBody(part0,L"This is the plain-text body.");
part1 = CkMimeW_Create();
CkMimeW_AddHeaderField(part1,L"hdrX",L"Some value X");
CkMimeW_AddHeaderField(part1,L"hdrY",L"Some value Y");
CkMimeW_putContentType(part1,L"text/xml");
CkMimeW_SetBody(part1,L"<a>This is the XML body</a>");
CkMimeW_AppendPart(mime,part0);
CkMimeW_AppendPart(mime,part1);
// The MIME to be encrypted:
sbMime = CkStringBuilderW_Create();
CkMimeW_GetMimeSb(mime,sbMime);
wprintf(L"%s\n",CkStringBuilderW_getAsString(sbMime));
// Content-Type: multipart/mixed; boundary="------------080303020600020604010008"
// someHeader1: Some value 1
// someHeader2: Some value 2
//
// --------------080303020600020604010008
// hdrA: Some value A
// hdrB: Some value B
// Content-Type: text/plain
//
// This is the plain-text body.
// --------------080303020600020604010008
// hdrX: Some value X
// hdrY: Some value Y
// Content-Type: text/xml
//
// <a>This is the XML body</a>
// --------------080303020600020604010008--
//
// Load an RSA-based certificate.
// (Encrypting MIME only requires the public key. Decrypting MIME requires the private key.)
cert = CkCertW_Create();
success = CkCertW_LoadFromFile(cert,L"qa_data/rsaes-oaep/cert.pem");
if (success != TRUE) {
wprintf(L"%s\n",CkCertW_lastErrorText(cert));
CkMimeW_Dispose(mime);
CkMimeW_Dispose(part0);
CkMimeW_Dispose(part1);
CkStringBuilderW_Dispose(sbMime);
CkCertW_Dispose(cert);
return;
}
// Set the email object properties to indicate the desired encryption.
CkMimeW_putPkcs7CryptAlg(mime,L"aes");
// If AES-256 is desired, set the following property to 256.
CkMimeW_putPkcs7KeyLength(mime,128);
CkMimeW_putOaepPadding(mime,TRUE);
// Other choices for the OAEP hash algorithm are "sha1", "sha384", and "sha512"
CkMimeW_putOaepHash(mime,L"sha256");
// Encrypt the MIME (to create S/MIME, which stands for "Secure MIME")
success = CkMimeW_Encrypt(mime,cert);
if (success != TRUE) {
wprintf(L"%s\n",CkMimeW_lastErrorText(mime));
CkMimeW_Dispose(mime);
CkMimeW_Dispose(part0);
CkMimeW_Dispose(part1);
CkStringBuilderW_Dispose(sbMime);
CkCertW_Dispose(cert);
return;
}
wprintf(L"---------------\n");
wprintf(L"Encrypted MIME:\n");
wprintf(L"---------------\n");
wprintf(L"%s\n",CkMimeW_getMime(mime));
wprintf(L"Success.\n");
// ---------------------------------------------------
// This is sample output for RSAES-OAEP encrypted MIME:
// ---------------------------------------------------
// Content-Type: application/x-pkcs7-mime; name="smime.p7m"; smime-type="enveloped-data"
// someHeader1: Some value 1
// someHeader2: Some value 2
// Content-Disposition: attachment; filename="smime.p7m"
// Content-Transfer-Encoding: base64
//
// MIIDvAYJKoZIhvcNAQcDoIIDrTCCA6kCAQAxggGgMIIBnAIBADB1MGgxCzAJBgNVBAYTAlVTMQsw
// CQYDVQQIDAJJTDEQMA4GA1UEBwwHV2hlYXRvbjEhMB8GA1UECgwYSW50ZXJuZXQgV2lkZ2l0cyBQ
// dHkgTHRkMRcwFQYDVQQDDA5DaGlsa2F0V2lkZ2V0cwIJAMRwugDmvniwMBwGCSqGSIb3DQEBBzAP
// oA0wCwYJYIZIAWUDBAIBBIIBAFaUL1ga1bOrdqYKcMm+FHUacBvzfBxk0fnPA0AMBdN8BvTWT3CN
// YuqBhjOGyq0FpYD9pVZybUuFMCVsVyIW2O62HnsOK58YaPEUUcdH2sI+yjqX9UAn0P0nVDSsVdeK
// W8x9kMfZg+3UP+y1q+lu7VRJO3f2C9oLQpTkc4VW4n7UOcUI0waykLCjCTL8lFDb7/J3GeuMKyhH
// 5riNz50kpbzqn7m2Ks9yA+QmcTdXclclGFr2vwEUFzSdT2pxh/vaUrogCxkYWbQ2eV7vZg6O4kV0
// aqHBqySkPTAzHKiHH8K8GVdlTuJ8350CpICa4T8w7/Ht5I7dyOPPKy4C+rVtrvcwggH+BgkqhkiG
// 9w0BBwEwHQYJYIZIAWUDBAECBBDTC2WNBN+z2I47/4Feu9YqgIIB0MZvl3nC/q/Wzil6HtfQTr12
// Q5moHY+ORzAa1P9XvX2ZUFhW530mV395mQw/A4o4ekmX9eRPEZquYzZPLT8hNeZIuNdhpcSQUmad
// rKnKkR0wKJ3jJ3LhOIohVBQSYs8kVDZKq6lJBIznlsurFelZoNEhyRschhteDZx5rb7fCe8c2+/O
// DHxaqaHCAzm/Bd7kcg6FFfuTZy3tu0PgP5IsXN4OFA3kkvwjAs4XsVS8jdIcmDNBkYieE8WmJOIm
// Mz7mh/CHWLgWfGKa0Dkb9RcbFgLwYNT3GzuXFw9XPbKkEZjEAtJajWbN6P0WQl96YYd9qZxUpGxZ
// zjTHEYzViUdUXolfpLufttrRXyxN1RFWhNFMFbv66xYqklMSgpdM/Mbk+EuvX6eXayDPvDBpfYMw
// NoRAzv1Ony2c0ez9rBemJICicxAzpuvHbRxdjYs63Dnv+TYgpBK12AxWWpPIjXvw0WQKgTC3Tg8s
// EnuGhpENqso/clJBEBSn4+2WhYtYbdI5sVme67lvqQl1Xxy3r18SWaQbyDOwgYi1E+54lMDOxMy0
// y0FPHk5pP45DnXWj+XORPp5LhuZr5mf62YOXSSUwR5P0cXy4Rc+pN5lhRQPCf5z2
CkMimeW_Dispose(mime);
CkMimeW_Dispose(part0);
CkMimeW_Dispose(part1);
CkStringBuilderW_Dispose(sbMime);
CkCertW_Dispose(cert);
}