![]() |
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
(AutoIt) 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.
; 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= $oSb = ObjCreate("Chilkat.StringBuilder") Local $bCrlf = True $oSb.AppendLine("MIICSgYJKoZIhvcNAQcDoIICOzCCAjcCAQAxggHiMIIB3gIBADCBljCBgTELMAkGA1UEBhMCSVQx",$bCrlf) $oSb.AppendLine("EDAOBgNVBAgMB0JlcmdhbW8xGTAXBgNVBAcMEFBvbnRlIFNhbiBQaWV0cm8xFzAVBgNVBAoMDkFj",$bCrlf) $oSb.AppendLine("dGFsaXMgUy5wLkEuMSwwKgYDVQQDDCNBY3RhbGlzIENsaWVudCBBdXRoZW50aWNhdGlvbiBDQSBH",$bCrlf) $oSb.AppendLine("MwIQPCWvkSv8oQ7xRmEHJ6TzEDA8BgkqhkiG9w0BAQcwL6APMA0GCWCGSAFlAwQCAQUAoRwwGgYJ",$bCrlf) $oSb.AppendLine("KoZIhvcNAQEIMA0GCWCGSAFlAwQCAQUABIIBAKqHAPQNSsQoX7B2NH7QyEOWQRsSVs8oCHXmy8f4",$bCrlf) $oSb.AppendLine("MVZD2er3bvYUCIomxpwbLEAl14qjUIMynahooYGgqip7+4FqL301G+BVjZVfEhHWj+VI1dAWnWuL",$bCrlf) $oSb.AppendLine("VHlvc/pbQNBWqV8rKVJsNIsuAZkdj4WSwLVKxYkYX43B8fh/g71XN2DTJu7Z/824v48KBmgpQBOT",$bCrlf) $oSb.AppendLine("2q7IcDGxNPAFN2p6eavIVGn2LvhEbf/Fszyj+GR5tMcnQP1BOLJ3s3JzUBbvj8hcZrF1Vhl9HnTU",$bCrlf) $oSb.AppendLine("YQx8G/KdW1mR+Wlhl3BWoK0LYKRTbnTx2BXOs0CY1SXOAdhKr01ZYjA+xW4nGzY0lfXS9QZjh9gw",$bCrlf) $oSb.AppendLine("TAYJKoZIhvcNAQcBMB0GCWCGSAFlAwQBKgQQw0xTbfmnt0zjWHo5SaQIp4AgxTVY9E/Ncqy6t+RM",$bCrlf) $oSb.AppendLine("8y4c3Av62/wB8IpPUEmtM2OeuZo=",$bCrlf) $oCrypt = ObjCreate("Chilkat.Crypt2") $oCrypt.CryptAlgorithm = "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. $oCrypt.EncodingMode = "base64" $oCrypt.Charset = "utf-8" Local $sDecryptedText = $oCrypt.DecryptStringENC($oSb.GetAsString()) If ($oCrypt.LastMethodSuccess = False) Then ConsoleWrite($oCrypt.LastErrorText & @CRLF) Exit EndIf ConsoleWrite($sDecryptedText & @CRLF) ; We can get the digital certificate used for decryption by calling LastDecryptCert $oCert = ObjCreate("Chilkat.Cert") Local $bSuccess = $oCrypt.LastDecryptCert($oCert) If ($oCrypt.LastMethodSuccess = False) Then ConsoleWrite($oCrypt.LastErrorText & @CRLF) Exit EndIf ConsoleWrite("Cert used to decrypt: " & $oCert.SubjectCN & @CRLF) |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.