Sample code for 30+ languages & platforms
Classic ASP

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 Classic ASP Downloads

Classic ASP
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0

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

set crypt = Server.CreateObject("Chilkat.Crypt2")

crypt.CryptAlgorithm = "aes"
crypt.CipherMode = "cbc"
crypt.KeyLength = 256

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

fileToEncrypt = "qa_data/hamlet.xml"
set facIn = Server.CreateObject("Chilkat.FileAccess")
success = facIn.OpenForRead(fileToEncrypt)
If (success <> 1) Then
    Response.Write "<pre>" & Server.HTMLEncode( "Failed to open file that is to be encrytped.") & "</pre>"
    Response.End
End If

outputEncryptedFile = "c:/temp/qa_output/hamlet.enc"
set facOutEnc = Server.CreateObject("Chilkat.FileAccess")
success = facOutEnc.OpenForWrite(outputEncryptedFile)
If (success <> 1) Then
    Response.Write "<pre>" & Server.HTMLEncode( "Failed to encrypted output file.") & "</pre>"
    Response.End
End If

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

crypt.FirstChunk = 1
crypt.LastChunk = 0

set bd = Server.CreateObject("Chilkat.BinData")

i = 0
Do While i < numChunks
    i = i + 1
    If (i = numChunks) Then
        crypt.LastChunk = 1
    End If

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

    ' Encrypt.
    success = crypt.EncryptBd(bd)

    ' Write the encrypted chunk to the output file.
    success = facOutEnc.FileWriteBd(bd,0,0)

    crypt.FirstChunk = 0
Loop

' Make sure both FirstChunk and LastChunk are restored to 1 after
' encrypting or decrypting in chunks.  Otherwise subsequent encryptions/decryptions
' will produce unexpected results.
crypt.FirstChunk = 1
crypt.LastChunk = 1

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)
Response.Write "<pre>" & Server.HTMLEncode( "bSame = " & bSame) & "</pre>"

%>
</body>
</html>