Unicode C
Unicode C
Decrypt MIME using RSAES-OAEP with SHA256 and AES-128 content encryption
See more MIME Examples
Demonstrates how to decrypt MIME what was encrypted with RSAES-OAEP with SHA256 and AES-128 content encryption.In actuality, we don't really need to know in advance the various algorithms used to encrypt the MIME. When decrypting, the information about the algorithms required are embedded in the PCKS7 message itself, and this tells a decryptor what it should use.
Note: This example requires Chilkat v9.5.0.67 or greater.
Chilkat Unicode C Downloads
#include <C_CkStringBuilderW.h>
#include <C_CkMimeW.h>
#include <C_CkCertW.h>
#include <C_CkPrivateKeyW.h>
void ChilkatSample(void)
{
BOOL success;
HCkStringBuilderW sb;
BOOL bCrlf;
HCkMimeW mime;
HCkCertW cert;
HCkPrivateKeyW privKey;
HCkMimeW mime2;
success = FALSE;
// This requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// We begin with this 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
sb = CkStringBuilderW_Create();
bCrlf = TRUE;
CkStringBuilderW_AppendLine(sb,L"Content-Type: application/x-pkcs7-mime; name=\"smime.p7m\"; smime-type=\"enveloped-data\"",bCrlf);
CkStringBuilderW_AppendLine(sb,L"someHeader1: Some value 1",bCrlf);
CkStringBuilderW_AppendLine(sb,L"someHeader2: Some value 2",bCrlf);
CkStringBuilderW_AppendLine(sb,L"Content-Disposition: attachment; filename=\"smime.p7m\"",bCrlf);
CkStringBuilderW_AppendLine(sb,L"Content-Transfer-Encoding: base64",bCrlf);
CkStringBuilderW_AppendLine(sb,L"",bCrlf);
CkStringBuilderW_AppendLine(sb,L"MIIDvAYJKoZIhvcNAQcDoIIDrTCCA6kCAQAxggGgMIIBnAIBADB1MGgxCzAJBgNVBAYTAlVTMQsw",bCrlf);
CkStringBuilderW_AppendLine(sb,L"CQYDVQQIDAJJTDEQMA4GA1UEBwwHV2hlYXRvbjEhMB8GA1UECgwYSW50ZXJuZXQgV2lkZ2l0cyBQ",bCrlf);
CkStringBuilderW_AppendLine(sb,L"dHkgTHRkMRcwFQYDVQQDDA5DaGlsa2F0V2lkZ2V0cwIJAMRwugDmvniwMBwGCSqGSIb3DQEBBzAP",bCrlf);
CkStringBuilderW_AppendLine(sb,L"oA0wCwYJYIZIAWUDBAIBBIIBAFaUL1ga1bOrdqYKcMm+FHUacBvzfBxk0fnPA0AMBdN8BvTWT3CN",bCrlf);
CkStringBuilderW_AppendLine(sb,L"YuqBhjOGyq0FpYD9pVZybUuFMCVsVyIW2O62HnsOK58YaPEUUcdH2sI+yjqX9UAn0P0nVDSsVdeK",bCrlf);
CkStringBuilderW_AppendLine(sb,L"W8x9kMfZg+3UP+y1q+lu7VRJO3f2C9oLQpTkc4VW4n7UOcUI0waykLCjCTL8lFDb7/J3GeuMKyhH",bCrlf);
CkStringBuilderW_AppendLine(sb,L"5riNz50kpbzqn7m2Ks9yA+QmcTdXclclGFr2vwEUFzSdT2pxh/vaUrogCxkYWbQ2eV7vZg6O4kV0",bCrlf);
CkStringBuilderW_AppendLine(sb,L"aqHBqySkPTAzHKiHH8K8GVdlTuJ8350CpICa4T8w7/Ht5I7dyOPPKy4C+rVtrvcwggH+BgkqhkiG",bCrlf);
CkStringBuilderW_AppendLine(sb,L"9w0BBwEwHQYJYIZIAWUDBAECBBDTC2WNBN+z2I47/4Feu9YqgIIB0MZvl3nC/q/Wzil6HtfQTr12",bCrlf);
CkStringBuilderW_AppendLine(sb,L"Q5moHY+ORzAa1P9XvX2ZUFhW530mV395mQw/A4o4ekmX9eRPEZquYzZPLT8hNeZIuNdhpcSQUmad",bCrlf);
CkStringBuilderW_AppendLine(sb,L"rKnKkR0wKJ3jJ3LhOIohVBQSYs8kVDZKq6lJBIznlsurFelZoNEhyRschhteDZx5rb7fCe8c2+/O",bCrlf);
CkStringBuilderW_AppendLine(sb,L"DHxaqaHCAzm/Bd7kcg6FFfuTZy3tu0PgP5IsXN4OFA3kkvwjAs4XsVS8jdIcmDNBkYieE8WmJOIm",bCrlf);
CkStringBuilderW_AppendLine(sb,L"Mz7mh/CHWLgWfGKa0Dkb9RcbFgLwYNT3GzuXFw9XPbKkEZjEAtJajWbN6P0WQl96YYd9qZxUpGxZ",bCrlf);
CkStringBuilderW_AppendLine(sb,L"zjTHEYzViUdUXolfpLufttrRXyxN1RFWhNFMFbv66xYqklMSgpdM/Mbk+EuvX6eXayDPvDBpfYMw",bCrlf);
CkStringBuilderW_AppendLine(sb,L"NoRAzv1Ony2c0ez9rBemJICicxAzpuvHbRxdjYs63Dnv+TYgpBK12AxWWpPIjXvw0WQKgTC3Tg8s",bCrlf);
CkStringBuilderW_AppendLine(sb,L"EnuGhpENqso/clJBEBSn4+2WhYtYbdI5sVme67lvqQl1Xxy3r18SWaQbyDOwgYi1E+54lMDOxMy0",bCrlf);
CkStringBuilderW_AppendLine(sb,L"y0FPHk5pP45DnXWj+XORPp5LhuZr5mf62YOXSSUwR5P0cXy4Rc+pN5lhRQPCf5z2",bCrlf);
// Load the encrypted MIME into the MIME object.
mime = CkMimeW_Create();
CkMimeW_LoadMimeSb(mime,sb);
// Provide the required cert + private key from a PFX (.pfx/.p12) file.
success = CkMimeW_AddPfxSourceFile(mime,L"qa_data/rsaes-oaep/cert_plus_privatekey.pfx",L"PFX_PASSWORD");
if (success != TRUE) {
wprintf(L"%s\n",CkMimeW_lastErrorText(mime));
CkStringBuilderW_Dispose(sb);
CkMimeW_Dispose(mime);
return;
}
// Decrypt.
success = CkMimeW_Decrypt(mime);
if (success != TRUE) {
wprintf(L"%s\n",CkMimeW_lastErrorText(mime));
CkStringBuilderW_Dispose(sb);
CkMimeW_Dispose(mime);
return;
}
// Examine the decrypted MIME.
wprintf(L"%s\n",CkMimeW_getMime(mime));
wprintf(L"Decrypt test 1 succeeded.\n");
// -----------------------------------------------------------
// Now let's decrypt another way..
// We have the same cert and private key in PEM files..
cert = CkCertW_Create();
success = CkCertW_LoadFromFile(cert,L"qa_data/rsaes-oaep/cert.pem");
privKey = CkPrivateKeyW_Create();
success = CkPrivateKeyW_LoadPemFile(privKey,L"qa_data/rsaes-oaep/privatekey.pem");
// Decrypt using the cert + private key
mime2 = CkMimeW_Create();
CkMimeW_LoadMimeSb(mime2,sb);
success = CkMimeW_Decrypt2(mime2,cert,privKey);
if (success != TRUE) {
wprintf(L"%s\n",CkMimeW_lastErrorText(mime2));
CkStringBuilderW_Dispose(sb);
CkMimeW_Dispose(mime);
CkCertW_Dispose(cert);
CkPrivateKeyW_Dispose(privKey);
CkMimeW_Dispose(mime2);
return;
}
// Examine the decrypted MIME.
wprintf(L"%s\n",CkMimeW_getMime(mime2));
wprintf(L"Decrypt test 2 succeeded.\n");
CkStringBuilderW_Dispose(sb);
CkMimeW_Dispose(mime);
CkCertW_Dispose(cert);
CkPrivateKeyW_Dispose(privKey);
CkMimeW_Dispose(mime2);
}