(JavaScript) Add Custom Extra Data to a Gzip File
This example demonstrates how to use the SetExtraData method to include custom binary data in the Gzip header using a hex-encoded string.
The hex string represents the raw bytes to embed in the Gzip metadata. When a compression method is called, this data is included in the Gzip header.
The example also shows how to retrieve the metadata using GetGzipInfo to verify that the extra data was successfully embedded. The retrieved value is returned as a Base64-encoded string.
var success = false;
// This example demonstrates how to include custom extra data
// in the Gzip header when compressing.
// The extra data is provided as a hex-encoded string.
var gzip = new CkGzip();
var json = new CkJsonObject();
// Set extra data using a hex string.
// This example represents 4 bytes: 00 01 02 03
success = gzip.SetExtraData("00010203","hex");
if (success == false) {
console.log(gzip.LastErrorText);
return;
}
// Compress a file so the extra data is embedded in the Gzip header:
var inputFile = "example.txt";
var outputFile = "example.txt.gz";
success = gzip.CompressFile(inputFile,outputFile);
if (success == false) {
console.log(gzip.LastErrorText);
return;
}
console.log("Gzip file created with extra data.");
// (Optional) Retrieve the metadata to verify:
success = gzip.GetGzipInfo(outputFile,json);
if (success == false) {
console.log(gzip.LastErrorText);
return;
}
console.log("Metadata JSON:");
console.log(json.Emit());
|