Sample code for 30+ languages & platforms
Classic ASP

AES GCM Encrypt and Decrypt a File

See more Encryption Examples

Demonstrates how to AES GCM encrypt and decrypt a file.

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")

' Set the encryption algorithm to "AES"	
crypt.CryptAlgorithm = "aes"

' Indicate that the Galois/Counter Mode (GCM) should be used:
crypt.CipherMode = "gcm"

' KeyLength may be 128, 192, 256
crypt.KeyLength = 256

' This is the 256-bit AES secret key (in hex format)
K = "000102030405060708090A0B0C0D0E0F000102030405060708090A0B0C0D0E0F"

' This is the 16-byte initialization vector (in hex format)
IV = "000102030405060708090A0B0C0D0E0F"

' This is the OPTIONAL additional data (in hex format) to be used as input to the GCM AEAD algorithm,
' but is not included in the output.  It plays a role in the computation of the
' resulting authenticated tag.
AAD = "feedfacedeadbeeffeedfacedeadbeefabaddad2"

' Set the secret key and IV
crypt.SetEncodedIV IV,"hex"
crypt.SetEncodedKey K,"hex"

' Set the additional authenticated data (AAD)
success = crypt.SetEncodedAad(AAD,"hex")

' Encrypt a file.
inFile = "qa_data/hamlet.xml"
outFile = "c:/temp/qa_output/hamlet_aes_gcm.enc"
success = crypt.CkEncryptFile(inFile,outFile)
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( crypt.LastErrorText) & "</pre>"
    Response.End
End If

' Get the authentication tag in hex format
authTag = crypt.GetEncodedAuthTag("hex")
Response.Write "<pre>" & Server.HTMLEncode( "authentication tag = " & authTag) & "</pre>"

' Decrypt..

' Before decrypting, you must provide the expected authentication tag.
' The decrypt will fail if the resulting authentication tag computed while decrypting is not equal to the
' expected authentication tag.
success = crypt.SetEncodedAuthTag(authTag,"hex")

inFile = outFile
outFile = "c:/temp/qa_output/hamlet_restored.xml"
success = crypt.CkDecryptFile(inFile,outFile)
If (success = 0) Then
    Response.Write "<pre>" & Server.HTMLEncode( crypt.LastErrorText) & "</pre>"
    Response.End
End If

Response.Write "<pre>" & Server.HTMLEncode( "Success.") & "</pre>"

' --------------------------------------------------------------------------------------------
' About AES-GCM:

' AES-GCM (Advanced Encryption Standard - Galois/Counter Mode) is a widely-used
' encryption mode that provides both confidentiality (encryption) and
' integrity/authentication (data integrity verification) in one operation. It is
' commonly used in secure communications due to its efficiency and strong security
' properties.
' 
' Key Concepts:
' 
'     AES (Advanced Encryption Standard):
' 
'         AES is a symmetric encryption algorithm, meaning the same key is used
'         for both encryption and decryption.
' 
'         It operates on fixed-size blocks of data (128 bits) using key sizes of
'         128, 192, or 256 bits.
' 
'         In AES-GCM, AES is used to perform the actual data encryption.
' 
'     GCM (Galois/Counter Mode):
' 
'         Counter Mode (CTR): GCM uses counter mode for encryption. In this mode,
'         a nonce (or initialization vector, IV) and a counter are combined and encrypted
'         with AES. The result is XORed with the plaintext to produce the ciphertext. 
' 
'         Galois Mode (GMAC): GCM also includes an authentication mechanism based
'         on a Galois field. It generates an authentication tag, which ensures the
'         integrity of both the ciphertext and any additional data (called AAD -
'         Additional Authenticated Data). This tag is verified during decryption to ensure
'         that the data hasn't been tampered with.
' 
' Key Features:
' 
'     Confidentiality (Encryption):
' 
'         The plaintext is encrypted using AES in counter mode. Each block of
'         plaintext is XORed with the output of AES applied to a combination of the IV and
'         an incremented counter.
' 
'     Integrity (Authentication):
' 
'         In addition to encryption, GCM provides authentication for both the
'         encrypted data (ciphertext) and any Additional Authenticated Data (AAD), such as
'         headers or metadata that need to be protected but not encrypted.
' 
'         The authentication tag is generated using a Galois field multiplication
'         of the ciphertext and AAD. This ensures that any changes to the encrypted
'         message or the AAD will be detected during decryption.
' 
' Key Components:
' 
'     - Plaintext: The data you want to encrypt.
'     - Ciphertext: The encrypted data.
'     - Key: A symmetric key used for both encryption and decryption.
'     - Nonce/IV: A unique value used for each encryption to ensure security. It is not secret but should never be reused with the same key.
'     - AAD (Additional Authenticated Data): Optional data that is not encrypted but needs to be authenticated (e.g., headers).
'     - Authentication Tag: A tag generated to verify the integrity and authenticity of the ciphertext and AAD

%>
</body>
</html>