![]() |
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
(Go) Create PKCS7 (CMS) EnvelopedDataEncrypt some data to a recipient by creating a PKCS7 (CMS) EnvelopedData structure. The data will be encrypted using a symmetric content-encryption algorithm (e.g., AES), and the randomly generated symmetric key will be encrypted using the recipient’s RSA public key extracted from their X.509 certificate.
crypt := Crypt2_Ref.html">chilkat.NewCrypt2() // Specify the encryption to be used. // "pki" indicates "Public Key Infrastructure" and will create a PKCS7 encrypted (enveloped-data) message. crypt.SetCryptAlgorithm("pki") crypt.SetPkcs7CryptAlg("aes") crypt.SetKeyLength(256) crypt.SetOaepHash("sha256") crypt.SetOaepPadding(true) cert := Cert_Ref.html">chilkat.NewCert() // Use a certificate found in the Windows certificate store. success := cert.LoadByCommonName("My Certificate") if success != true { fmt.Println(cert.LastErrorText()) crypt.DisposeCrypt2() cert.DisposeCert() return } // Tell the crypt object to use the certificate. crypt.SetEncryptCert(cert) toBeEncrypted := "This string is to be encrypted." // Get the result in multi-line BASE64 MIME format. crypt.SetEncodingMode("base64_mime") crypt.SetCharset("utf-8") result := crypt.EncryptStringENC(toBeEncrypted) if success != true { fmt.Println(crypt.LastErrorText()) crypt.DisposeCrypt2() cert.DisposeCert() return } // ------------------------------------------------------------------------- // See the following example to decrypt what was created in this example // Decrypt PKCS7 (CMS) EnvelopedData // ------------------------------------------------------------------------- fmt.Println(*result) // Sample output: // 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= crypt.DisposeCrypt2() cert.DisposeCert() |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.