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