C++
C++
Encrypt Already Existing Zip
See more Zip Examples
To encrypt an already existing non-encrypted .zip, the application must open the .zip, set the encryption related properties, and then re-write.Chilkat C++ Downloads
#include <CkZip.h>
void ChilkatSample(void)
{
bool success = false;
// This requires the Chilkat Zip API to have been previously unlocked.
// See Unlock Chilkat Zip for sample code.
CkZip zip;
// Open an unencrypted .zip
success = zip.OpenZip("qa_data/zips/test.zip");
if (success != true) {
std::cout << zip.lastErrorText() << "\r\n";
return;
}
// Unzip to a temp directory.
int numFilesUnzipped = zip.Unzip("qa_output/tmp");
if (numFilesUnzipped < 0) {
std::cout << zip.lastErrorText() << "\r\n";
return;
}
// Clear the zip object.
zip.NewZip("qa_output/aesTest.zip");
// Indicate that 128-bit AES encryption is to be used when writing the .zip
zip.put_Encryption(4);
zip.put_EncryptKeyLength(128);
// Set the password.
zip.put_EncryptPassword("secret");
// Append the files.
zip.put_AppendFromDir("qa_output/tmp");
success = zip.AppendFiles("*.*",true);
if (success != true) {
std::cout << zip.lastErrorText() << "\r\n";
return;
}
// Write the .zip and close it.
success = zip.WriteZipAndClose();
if (success != true) {
std::cout << zip.lastErrorText() << "\r\n";
return;
}
std::cout << "Success." << "\r\n";
}