![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Tcl) Decrypt PKCS7 (CMS) EnvelopedDataThis example receives a PKCS7 (CMS) EnvelopedData message that was encrypted to me. To decrypt it:
Summary:
Only the intended recipient, who possesses the correct private key, can successfully decrypt the EnvelopedData. Note: This example requires Chilkat v11.0.0 or greater.
load ./chilkat.dll # Here's the PKCS7 (CMS) EnvelopedData we received. # It was created using this example: Create PKCS7 CMS EnvelopedData # MIICSgYJKoZIhvcNAQcDoIICOzCCAjcCAQAxggHiMIIB3gIBADCBljCBgTELMAkGA1UEBhMCSVQx # EDAOBgNVBAgMB0JlcmdhbW8xGTAXBgNVBAcMEFBvbnRlIFNhbiBQaWV0cm8xFzAVBgNVBAoMDkFj # dGFsaXMgUy5wLkEuMSwwKgYDVQQDDCNBY3RhbGlzIENsaWVudCBBdXRoZW50aWNhdGlvbiBDQSBH # MwIQPCWvkSv8oQ7xRmEHJ6TzEDA8BgkqhkiG9w0BAQcwL6APMA0GCWCGSAFlAwQCAQUAoRwwGgYJ # KoZIhvcNAQEIMA0GCWCGSAFlAwQCAQUABIIBAKqHAPQNSsQoX7B2NH7QyEOWQRsSVs8oCHXmy8f4 # MVZD2er3bvYUCIomxpwbLEAl14qjUIMynahooYGgqip7+4FqL301G+BVjZVfEhHWj+VI1dAWnWuL # VHlvc/pbQNBWqV8rKVJsNIsuAZkdj4WSwLVKxYkYX43B8fh/g71XN2DTJu7Z/824v48KBmgpQBOT # 2q7IcDGxNPAFN2p6eavIVGn2LvhEbf/Fszyj+GR5tMcnQP1BOLJ3s3JzUBbvj8hcZrF1Vhl9HnTU # YQx8G/KdW1mR+Wlhl3BWoK0LYKRTbnTx2BXOs0CY1SXOAdhKr01ZYjA+xW4nGzY0lfXS9QZjh9gw # TAYJKoZIhvcNAQcBMB0GCWCGSAFlAwQBKgQQw0xTbfmnt0zjWHo5SaQIp4AgxTVY9E/Ncqy6t+RM # 8y4c3Av62/wB8IpPUEmtM2OeuZo= set sb [new_CkStringBuilder] set bCrlf 1 CkStringBuilder_AppendLine $sb "MIICSgYJKoZIhvcNAQcDoIICOzCCAjcCAQAxggHiMIIB3gIBADCBljCBgTELMAkGA1UEBhMCSVQx" $bCrlf CkStringBuilder_AppendLine $sb "EDAOBgNVBAgMB0JlcmdhbW8xGTAXBgNVBAcMEFBvbnRlIFNhbiBQaWV0cm8xFzAVBgNVBAoMDkFj" $bCrlf CkStringBuilder_AppendLine $sb "dGFsaXMgUy5wLkEuMSwwKgYDVQQDDCNBY3RhbGlzIENsaWVudCBBdXRoZW50aWNhdGlvbiBDQSBH" $bCrlf CkStringBuilder_AppendLine $sb "MwIQPCWvkSv8oQ7xRmEHJ6TzEDA8BgkqhkiG9w0BAQcwL6APMA0GCWCGSAFlAwQCAQUAoRwwGgYJ" $bCrlf CkStringBuilder_AppendLine $sb "KoZIhvcNAQEIMA0GCWCGSAFlAwQCAQUABIIBAKqHAPQNSsQoX7B2NH7QyEOWQRsSVs8oCHXmy8f4" $bCrlf CkStringBuilder_AppendLine $sb "MVZD2er3bvYUCIomxpwbLEAl14qjUIMynahooYGgqip7+4FqL301G+BVjZVfEhHWj+VI1dAWnWuL" $bCrlf CkStringBuilder_AppendLine $sb "VHlvc/pbQNBWqV8rKVJsNIsuAZkdj4WSwLVKxYkYX43B8fh/g71XN2DTJu7Z/824v48KBmgpQBOT" $bCrlf CkStringBuilder_AppendLine $sb "2q7IcDGxNPAFN2p6eavIVGn2LvhEbf/Fszyj+GR5tMcnQP1BOLJ3s3JzUBbvj8hcZrF1Vhl9HnTU" $bCrlf CkStringBuilder_AppendLine $sb "YQx8G/KdW1mR+Wlhl3BWoK0LYKRTbnTx2BXOs0CY1SXOAdhKr01ZYjA+xW4nGzY0lfXS9QZjh9gw" $bCrlf CkStringBuilder_AppendLine $sb "TAYJKoZIhvcNAQcBMB0GCWCGSAFlAwQBKgQQw0xTbfmnt0zjWHo5SaQIp4AgxTVY9E/Ncqy6t+RM" $bCrlf CkStringBuilder_AppendLine $sb "8y4c3Av62/wB8IpPUEmtM2OeuZo=" $bCrlf set crypt [new_CkCrypt2] CkCrypt2_put_CryptAlgorithm $crypt "pki" # The CMS message contains information about the digital certificate that was used to encrypt. # Assuming the certificate is installed in a Windows certificate store, or macOS keychain, # Chilkat will automatically locate and use the certificate + private key for decryption. CkCrypt2_put_EncodingMode $crypt "base64" CkCrypt2_put_Charset $crypt "utf-8" set decryptedText [CkCrypt2_decryptStringENC $crypt [CkStringBuilder_getAsString $sb]] if {[CkCrypt2_get_LastMethodSuccess $crypt] == 0} then { puts [CkCrypt2_lastErrorText $crypt] delete_CkStringBuilder $sb delete_CkCrypt2 $crypt exit } puts "$decryptedText" # We can get the digital certificate used for decryption by calling LastDecryptCert set cert [new_CkCert] set success [CkCrypt2_LastDecryptCert $crypt $cert] if {[CkCrypt2_get_LastMethodSuccess $crypt] == 0} then { puts [CkCrypt2_lastErrorText $crypt] delete_CkStringBuilder $sb delete_CkCrypt2 $crypt delete_CkCert $cert exit } puts "Cert used to decrypt: [CkCert_subjectCN $cert]" delete_CkStringBuilder $sb delete_CkCrypt2 $crypt delete_CkCert $cert |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.