Sample code for 30+ languages & platforms
PureBasic

Encrypt/Decrypt using PFX to produce -----BEGIN PKCS7----- ... -----END PKCS7-----

See more Encryption Examples

First we encrypt using a certificate + public key to produce output such as:
-----BEGIN PKCS7-----
MIIHPwYJKoZIhvcNAQcEoIIHMDCCBywC ...
...
...
-----END PKCS7-----
Then we decrypt using the cert + private key.

Chilkat PureBasic Downloads

PureBasic
IncludeFile "CkCert.pb"
IncludeFile "CkStringBuilder.pb"
IncludeFile "CkCrypt2.pb"

Procedure ChilkatExample()

    success.i = 0

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

    crypt.i = CkCrypt2::ckCreate()
    If crypt.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    ; Specify the encryption to be used.
    ; "pki" indicates "Public Key Infrastructure" and will create a PKCS7 encrypted (enveloped) message.
    CkCrypt2::setCkCryptAlgorithm(crypt, "pki")
    CkCrypt2::setCkPkcs7CryptAlg(crypt, "aes")
    CkCrypt2::setCkKeyLength(crypt, 128)
    CkCrypt2::setCkOaepHash(crypt, "sha256")
    CkCrypt2::setCkOaepPadding(crypt, 1)

    ; A certificate is needed as the encryption key.
    ; Althought the PFX contains the associated private key, we don't need it for encryption.
    ; (A certificate usually contains the public key by default.)
    cert.i = CkCert::ckCreate()
    If cert.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    success = CkCert::ckLoadPfxFile(cert,"qa_data/pfx/cert_test123.pfx","test123")
    If success <> 1
        Debug CkCert::ckLastErrorText(cert)
        CkCrypt2::ckDispose(crypt)
        CkCert::ckDispose(cert)
        ProcedureReturn
    EndIf

    ; Tell the crypt object to use the certificate.
    CkCrypt2::ckSetEncryptCert(crypt,cert)

    toBeEncrypted.s = "This string is to be encrypted."

    ; Get the result in multi-line BASE64 MIME format.
    CkCrypt2::setCkEncodingMode(crypt, "base64_mime")

    encryptedStr.s = CkCrypt2::ckEncryptStringENC(crypt,toBeEncrypted)
    If success <> 1
        Debug CkCrypt2::ckLastErrorText(crypt)
        CkCrypt2::ckDispose(crypt)
        CkCert::ckDispose(cert)
        ProcedureReturn
    EndIf

    ; Make a "-----BEGIN PKCS7-----" ... "-----END PKCS7-----" sandwich...
    sb.i = CkStringBuilder::ckCreate()
    If sb.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    CkStringBuilder::ckAppendLine(sb,"-----BEGIN PKCS7-----",1)
    CkStringBuilder::ckAppend(sb,encryptedStr)
    CkStringBuilder::ckAppendLine(sb,"-----END PKCS7-----",1)

    outStr.s = CkStringBuilder::ckGetAsString(sb)

    Debug outStr

    ; Sample output:

    ; -----BEGIN PKCS7-----
    ; MIICXAYJKoZIhvcNAQcDoIICTTCCAkkCAQAxggH0MIIB8AIBADCBrDCBlzELMAkGA1UEBhMCR0Ix
    ; GzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMR
    ; Q09NT0RPIENBIExpbWl0ZWQxPTA7BgNVBAMTNENPTU9ETyBSU0EgQ2xpZW50IEF1dGhlbnRpY2F0
    ; aW9uIGFuZCBTZWN1cmUgRW1haWwgQ0ECEB6M1ZwZdZU7LrAIdurulmUwOAYJKoZIhvcNAQEHMCug
    ; DzANBglghkgBZQMEAgEFAKEYMBYGCSqGSIb3DQEBCDAJBgUrDgMCGgUABIIBAK/BZG/iXJ8az7zL
    ; 8EQ77mc+oDPQ4w1hyytK2ip4djkPVvTfYhcoDQ+G/DBU+urJfrVBi5H9gmpXwYyfKlyUxBVRVEJl
    ; V/V5QQi4JmNTFbmgWh5tp9zDS98l6A2Va4Zs0Wy/owGLfvwitlxd1dsfVAV2hmBYS24BMpNcty5/
    ; 0atcKYmSou13G78ztTKdMy1tECgZy8kerMsPdDQbSxEZkT3KpQ8C5uEQqYF3bIVaeZzha/Ywieh/
    ; tvO0T4aAmeJufwkNdVECmU7kuhnNaVPXknFl7jeibTl6zA/VcJKBKcIYT9FRC7KjdooI8q+jtQ/V
    ; k6RP4POaowkFg1QWRPEWeqIwTAYJKoZIhvcNAQcBMB0GCWCGSAFlAwQBAgQQEEFQduqeJqXQXzy4
    ; JpkoDoAgdldJDB9zEkpMpgr5/fR2iLvh5kC6BPfhOYjsawBY4Ok=
    ; -----END PKCS7-----

    ; ----------------------------------------------------------------------------------------
    ; Let's Decrypt the above string.

    ; Start with what was produced above..
    CkStringBuilder::ckClear(sb)
    bCrlf.i = 1
    CkStringBuilder::ckAppendLine(sb,"-----BEGIN PKCS7-----",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"MIICXAYJKoZIhvcNAQcDoIICTTCCAkkCAQAxggH0MIIB8AIBADCBrDCBlzELMAkGA1UEBhMCR0Ix",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"GzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMR",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"Q09NT0RPIENBIExpbWl0ZWQxPTA7BgNVBAMTNENPTU9ETyBSU0EgQ2xpZW50IEF1dGhlbnRpY2F0",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"aW9uIGFuZCBTZWN1cmUgRW1haWwgQ0ECEB6M1ZwZdZU7LrAIdurulmUwOAYJKoZIhvcNAQEHMCug",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"DzANBglghkgBZQMEAgEFAKEYMBYGCSqGSIb3DQEBCDAJBgUrDgMCGgUABIIBAK/BZG/iXJ8az7zL",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"8EQ77mc+oDPQ4w1hyytK2ip4djkPVvTfYhcoDQ+G/DBU+urJfrVBi5H9gmpXwYyfKlyUxBVRVEJl",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"V/V5QQi4JmNTFbmgWh5tp9zDS98l6A2Va4Zs0Wy/owGLfvwitlxd1dsfVAV2hmBYS24BMpNcty5/",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"0atcKYmSou13G78ztTKdMy1tECgZy8kerMsPdDQbSxEZkT3KpQ8C5uEQqYF3bIVaeZzha/Ywieh/",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"tvO0T4aAmeJufwkNdVECmU7kuhnNaVPXknFl7jeibTl6zA/VcJKBKcIYT9FRC7KjdooI8q+jtQ/V",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"k6RP4POaowkFg1QWRPEWeqIwTAYJKoZIhvcNAQcBMB0GCWCGSAFlAwQBAgQQEEFQduqeJqXQXzy4",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"JpkoDoAgdldJDB9zEkpMpgr5/fR2iLvh5kC6BPfhOYjsawBY4Ok=",bCrlf)
    CkStringBuilder::ckAppendLine(sb,"-----END PKCS7-----",bCrlf)

    decrypt.i = CkCrypt2::ckCreate()
    If decrypt.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    CkCrypt2::setCkCryptAlgorithm(decrypt, "pki")

    ; Use the same cert + private key from the PFX above.
    ; For decryption, we need the private key.  Given that the certificate was loaded from a PFX,
    ; we should already have it.
    success = CkCrypt2::ckSetDecryptCert(decrypt,cert)

    CkCrypt2::setCkEncodingMode(decrypt, "base64")
    decryptedText.s = CkCrypt2::ckDecryptStringENC(decrypt,CkStringBuilder::ckGetBetween(sb,"-----BEGIN PKCS7-----","-----END PKCS7-----"))

    Debug decryptedText


    CkCrypt2::ckDispose(crypt)
    CkCert::ckDispose(cert)
    CkStringBuilder::ckDispose(sb)
    CkCrypt2::ckDispose(decrypt)


    ProcedureReturn
EndProcedure