Sample code for 30+ languages & platforms
Tcl

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 Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

# This requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

set mime [new_CkMime]

# Create a MIME message to encrypt.
CkMime_NewMultipartMixed $mime
CkMime_AddHeaderField $mime "someHeader1" "Some value 1"
CkMime_AddHeaderField $mime "someHeader2" "Some value 2"

set part0 [new_CkMime]

CkMime_AddHeaderField $part0 "hdrA" "Some value A"
CkMime_AddHeaderField $part0 "hdrB" "Some value B"
CkMime_put_ContentType $part0 "text/plain"
CkMime_SetBody $part0 "This is the plain-text body."

set part1 [new_CkMime]

CkMime_AddHeaderField $part1 "hdrX" "Some value X"
CkMime_AddHeaderField $part1 "hdrY" "Some value Y"
CkMime_put_ContentType $part1 "text/xml"
CkMime_SetBody $part1 "<a>This is the XML body</a>"

CkMime_AppendPart $mime $part0
CkMime_AppendPart $mime $part1

# The MIME to be encrypted:
set sbMime [new_CkStringBuilder]

CkMime_GetMimeSb $mime $sbMime
puts [CkStringBuilder_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.)
set cert [new_CkCert]

set success [CkCert_LoadFromFile $cert "qa_data/rsaes-oaep/cert.pem"]
if {$success != 1} then {
    puts [CkCert_lastErrorText $cert]
    delete_CkMime $mime
    delete_CkMime $part0
    delete_CkMime $part1
    delete_CkStringBuilder $sbMime
    delete_CkCert $cert
    exit
}

# Set the email object properties to indicate the desired encryption.
CkMime_put_Pkcs7CryptAlg $mime "aes"
# If AES-256 is desired, set the following property to 256.
CkMime_put_Pkcs7KeyLength $mime 128
CkMime_put_OaepPadding $mime 1
# Other choices for the OAEP hash algorithm are "sha1", "sha384", and "sha512"
CkMime_put_OaepHash $mime "sha256"

# Encrypt the MIME (to create S/MIME, which stands for "Secure MIME")
set success [CkMime_Encrypt $mime $cert]
if {$success != 1} then {
    puts [CkMime_lastErrorText $mime]
    delete_CkMime $mime
    delete_CkMime $part0
    delete_CkMime $part1
    delete_CkStringBuilder $sbMime
    delete_CkCert $cert
    exit
}

puts "---------------"
puts "Encrypted MIME:"
puts "---------------"
puts [CkMime_getMime $mime]

puts "Success."

# ---------------------------------------------------
# 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

delete_CkMime $mime
delete_CkMime $part0
delete_CkMime $part1
delete_CkStringBuilder $sbMime
delete_CkCert $cert