Sample code for 30+ languages & platforms
Node.js

Duplicate openssl smime -encrypt -binary -aes-256-cbc -in some_file.dat -out some_file.dat.enc -outform DER cert.crt

See more OpenSSL Examples

Demonstrates how to encrypt to binary DER using 256-bit AES (CBC mode) as the underlying symmetric encryption algorithm, to produce PKCS7 enveloped data (binary DER).

Duplicates the following openssl command:

openssl smime -encrypt -binary -aes-256-cbc -in some_file.dat -out some_file.dat.enc -outform DER cert.crt

Chilkat Node.js Downloads

Node.js
NODEJS_PRELUDE

function chilkatExample() {

    var success = false;

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

    var cert = new chilkat.Cert();
    success = cert.LoadFromFile("qa_data/openssl/EE.cer");
    if (success == false) {
        console.log(cert.LastErrorText);
        return;
    }

    var bd = new chilkat.BinData();
    success = bd.LoadFile("qa_data/openssl/hello.txt");
    // Assuming success..

    var crypt = new chilkat.Crypt2();
    success = crypt.SetEncryptCert(cert);
    if (success == false) {
        console.log(crypt.LastErrorText);
        return;
    }

    crypt.CryptAlgorithm = "PKI";

    // Indicate the underlying symmetric encryption to be used:
    crypt.Pkcs7CryptAlg = "aes";
    crypt.KeyLength = 256;
    crypt.CipherMode = "cbc";

    success = crypt.CkEncryptFile("qa_data/openssl/hello.txt","qa_output/hello.txt.enc");
    if (success == false) {
        console.log(crypt.LastErrorText);
        return;
    }

    console.log("Success.");

}

chilkatExample();