Sample code for 30+ languages & platforms
Ruby

Encrypt File in Chunks using AES CBC

See more Encryption Examples

Demonstrates how to use the FirstChunk/LastChunk properties to encrypt a file chunk-by-chunk.

Chilkat Ruby Downloads

Ruby
require 'chilkat'

success = false

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

crypt = Chilkat::CkCrypt2.new()

crypt.put_CryptAlgorithm("aes")
crypt.put_CipherMode("cbc")
crypt.put_KeyLength(256)

crypt.SetEncodedKey("000102030405060708090A0B0C0D0E0F000102030405060708090A0B0C0D0E0F","hex")
crypt.SetEncodedIV("000102030405060708090A0B0C0D0E0F","hex")

fileToEncrypt = "qa_data/hamlet.xml"
facIn = Chilkat::CkFileAccess.new()
success = facIn.OpenForRead(fileToEncrypt)
if (success != true)
    print "Failed to open file that is to be encrytped." + "\n";
    exit
end

outputEncryptedFile = "c:/temp/qa_output/hamlet.enc"
facOutEnc = Chilkat::CkFileAccess.new()
success = facOutEnc.OpenForWrite(outputEncryptedFile)
if (success != true)
    print "Failed to encrypted output file." + "\n";
    exit
end

# Let's encrypt in 10000 byte chunks.
chunkSize = 10000
numChunks = facIn.GetNumBlocks(chunkSize)

crypt.put_FirstChunk(true)
crypt.put_LastChunk(false)

bd = Chilkat::CkBinData.new()

i = 0
while i < numChunks
    i = i + 1
    if (i == numChunks)
        crypt.put_LastChunk(true)
    end

    # Read the next chunk from the file.
    # The last chunk will be whatever amount remains in the file..
    bd.Clear()
    facIn.FileReadBd(chunkSize,bd)

    # Encrypt.
    crypt.EncryptBd(bd)

    # Write the encrypted chunk to the output file.
    facOutEnc.FileWriteBd(bd,0,0)

    crypt.put_FirstChunk(false)
end

# Make sure both FirstChunk and LastChunk are restored to true after
# encrypting or decrypting in chunks.  Otherwise subsequent encryptions/decryptions
# will produce unexpected results.
crypt.put_FirstChunk(true)
crypt.put_LastChunk(true)

facIn.FileClose()
facOutEnc.FileClose()

# Decrypt the encrypted output file in a single call using CBC mode:
decryptedFile = "qa_output/hamlet_dec.xml"
success = crypt.CkDecryptFile(outputEncryptedFile,decryptedFile)
# Assume success for the example..

# Compare the contents of the decrypted file with the original file:
bSame = facIn.FileContentsEqual(fileToEncrypt,decryptedFile)
print "bSame = " + bSame.to_s() + "\n";