Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(C++) Encrypt Already Existing ZipTo encrypt an already existing non-encrypted .zip, the application must open the .zip, set the encryption related properties, and then re-write.
#include <CkZip.h> void ChilkatSample(void) { // This requires the Chilkat Zip API to have been previously unlocked. // See Unlock Chilkat Zip for sample code. CkZip zip; // Open an unencrypted .zip bool 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"; } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.