ZIP-bestanden zijn de meest voorkomende typen archiefbestanden die worden gebruikt om gecomprimeerde bestanden en mappen in één container te bewaren. Als C#-ontwikkelaar kunt u eenvoudig programmatisch gecodeerde of met een wachtwoord beveiligde ZIP-archieven maken met behulp van C# in uw .NET-toepassingen. In dit artikel leer je hoe je gecodeerde ZIP-bestanden maakt met C#. In dit artikel worden de volgende onderwerpen besproken/behandeld:
- [C# API om gecodeerde ZIP-bestanden te maken][2]
- [Maak wachtwoordbeveiligde ZIP-bestanden aan][3]
- [Maak gecodeerde ZIP-bestanden met AES-codering][4]
- [Mappen in ZIP-bestanden versleutelen][5]
- [Versleutel specifieke bestanden in ZIP-archieven][6]
- [Maak versleutelde ZIP-bestanden met gemengde versleuteling][7]
C# API om gecodeerde ZIP-bestanden te maken
Voor het maken van versleutelde [ZIP][8]-archieven zal ik [Aspose.ZIP for .NET API][9] gebruiken. Hiermee kunt u bestanden en mappen comprimeren en toevoegen aan ZIP-archieven. Hiermee kunt u ook archieven van ondersteunde typen zoals ZIP, TAR, GZIP, BZ2, 7Zip, RAR, enz. Decomprimeren. De API biedt bescherming via door de gebruiker gedefinieerde wachtwoorden en traditionele coderingstechnieken met behulp van AES-codering zoals AES128, AES192 en AES256 . U kunt de DLL van de API [downloaden][10] of installeren met behulp van [NuGet][11].
Install-Package Aspose.ZIP
Creëer met een wachtwoord beveiligde ZIP-bestanden
U kunt eenvoudig programmatisch met een wachtwoord beveiligde ZIP-archieven maken door de onderstaande stappen te volgen:
- Maak een instantie van de klasse [Archive][12] met het object [ArchiveEntrySettings][13].
- Stel het wachtwoord in met behulp van het object [TraditionalEncryptionSettings][14].
- Roep de methode [CreatEntry()][15] aan met het invoerbestandspad om aan het archief toe te voegen.
- Herhaal bovenstaande stap om meerdere bestanden toe te voegen.
- Roep de methode [Save()][16] aan met het uitvoerbestandspad om het uitvoerbestand op te slaan.
Het volgende codevoorbeeld laat zien hoe u een met een wachtwoord beveiligd ZIP-bestand maakt met C#.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
// create an archive Archive archive = new Archive(new ArchiveEntrySettings(encryptionSettings: new TraditionalEncryptionSettings("12345"))); // Add files to the archive archive.CreateEntry("sample1.txt", "C:\\Files\\sample1.txt"); archive.CreateEntry("sample2.txt", "C:\\Files\\sample2.txt"); // save the archive archive.Save("C:\\Files\\password_protcted.zip");
De klasse Archive vertegenwoordigt een ZIP-archiefbestand. Het biedt verschillende methoden om ZIP-archieven te maken, samen te stellen, uit te pakken of bij te werken. De methode CreatEntry() van deze klasse maakt een enkel item van een bestand in het archief. Het neemt de naam van het bestand en het volledig gekwalificeerde bestandspad als invoerparameters. Deze klasse biedt ook overbelaste [CreatEntry()][18] methoden om bestanden uit stream of FileInfo toe te voegen. De methode Save() van deze klasse slaat het ZIP-archief op in het opgegeven bestandspad. De klasse ArchiveEntrySettings biedt instellingen voor het comprimeren of decomprimeren van de items. De klasse TraditionalEncryptionSetings biedt instellingen voor het traditionele ZipCrypto-algoritme. Het is een ZIP-algoritme voor wachtwoordbeveiliging. Met de eigenschap Password van deze klasse kunt u een wachtwoord verkrijgen of instellen voor het versleutelen of ontsleutelen van bestanden en mappen in een ZIP-archief.
Maak gecodeerde ZIP-bestanden met AES-codering
U kunt uw ZIP-archieven programmatisch coderen met AES-codering door de onderstaande stappen te volgen:
- Maak een instantie van de klasse [Archive][12] met het object [ArchiveEntrySettings][13].
- Stel het wachtwoord in met de klasse [AesEcryptionSettings][19]. Geef de wachtwoordreeks en de [EncryptionMethod][20] als argumenten door aan de constructor.
- Roep de methode [CreatEntry()][15] aan met het invoerbestandspad om aan het archief toe te voegen.
- Herhaal bovenstaande stap om meerdere bestanden toe te voegen.
- Roep de methode [Save()][16] aan met het uitvoerbestandspad om het uitvoerbestand op te slaan.
Het volgende codevoorbeeld laat zien hoe u een ZIP-bestand kunt maken dat is versleuteld met AES-versleuteling met behulp van C#.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
// create an archive Archive archive = new Archive(new ArchiveEntrySettings(null, new AesEcryptionSettings("p@s$", EncryptionMethod.AES128))); // Add files to the archive archive.CreateEntry("abc.txt", "C:\\Files\\sample1.txt"); // save the archive archive.Save("C:\\Files\\aes.zip");
- Traditioneel — Traditionele PKWARE-codering
- AES128 — Advanced Encryption Standard met sleutellengte 128 bits
- AES192 — Advanced Encryption Standard met sleutellengte 192 bits
- AES256 — Advanced Encryption Standard met sleutellengte 256 bits
Versleutel mappen in ZIP-bestanden
U kunt met een wachtwoord beveiligde mappen programmatisch toevoegen aan ZIP-bestanden door de onderstaande stappen te volgen:
- Maak een instantie van de klasse [Archive][12] met het object [ArchiveEntrySettings][13].
- Stel het wachtwoord in met behulp van het object [TraditionalEncryptionSettings][14].
- Roep de methode [CreatEntries()][21] aan met het mappad om aan het archief toe te voegen.
- Herhaal bovenstaande stap om meerdere mappen toe te voegen.
- Roep de methode [Save()][16] aan met het uitvoerbestandspad om het uitvoerbestand op te slaan.
Het volgende codevoorbeeld laat zien hoe een versleutelde map aan het ZIP-bestand kan worden toegevoegd met behulp van C#.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
// create an archive Archive archive = new Archive(new ArchiveEntrySettings(null, new TraditionalEncryptionSettings("123@45"))); // Add folder to the archive archive.CreateEntries("C:\\Files\\MyFolder"); // save the archive archive.Save("C:\\Files\\password_protcted_folder.zip");
Versleutel specifieke bestanden in ZIP-archieven
U kunt specifieke bestanden in de ZIP-archieven programmatisch versleutelen door de onderstaande stappen te volgen:
- Maak een instantie van de klasse [Archive][12].
- Roep de methode [CreatEntry()][15] aan met het invoerbestandspad om aan het archief toe te voegen.
- Stel het wachtwoord in voor het bestand met behulp van de ArchiveEntrySettings met de **TraditionalEncryptionSettings**.
- Roep de methode [CreatEntry()][15] aan met het invoerbestandspad om nog een bestand aan het archief toe te voegen.
- Herhaal bovenstaande stappen om meer bestanden toe te voegen.
- Roep de methode [Save()][16] aan met het uitvoerbestandspad om het uitvoerbestand op te slaan.
Het volgende codevoorbeeld laat zien hoe specifieke bestanden in het ZIP-archief versleuteld kunnen worden met C#.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
// create an archive Archive archive = new Archive(); // Add files to the archive archive.CreateEntry("sample1.txt", "C:\\Files\\sample1.txt"); archive.CreateEntry("sample2.txt", "C:\\Files\\sample2.txt", false, new ArchiveEntrySettings(encryptionSettings: new TraditionalEncryptionSettings("123@abc"))); // save the archive archive.Save("C:\\Files\\password_protcted.zip");
Maak gecodeerde ZIP-bestanden met gemengde codering
U kunt ZIP-archieven maken met bestanden en mappen die zijn beveiligd met gemengde coderingstechnieken die voor elk bestand en elke map programmatisch variëren door de onderstaande stappen te volgen:
- Maak een instantie van de klasse [Archive][12].
- Roep de methode [CreatEntry()][15] aan met het invoerbestandspad om aan het archief toe te voegen.
- Stel het wachtwoord in voor het bestand met behulp van de ArchiveEntrySettings met de AesEcryptionSettings.
- Roep de methode [CreatEntry()][15] aan met het invoerbestandspad om nog een bestand aan het archief toe te voegen.
- Stel het wachtwoord in voor het bestand met behulp van de ArchiveEntrySettings met de TraditionalEncryptionSettings.
- Roep de methode [CreatEntry()][15] aan met het invoerbestandspad om nog een bestand aan het archief toe te voegen.
- Roep de methode [CreateEntries()][21] aan met het mappad om toe te voegen aan het archief.
- Sla het uitvoerbestand op met behulp van de methode [Save()][16] met het uitvoerbestandspad.
Het volgende codevoorbeeld laat zien hoe u een ZIP-bestand maakt met gemengde coderingstechnieken met behulp van C#.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters
// create an archive Archive archive = new Archive(); // Add file with AES encryption to the archive archive.CreateEntry("sample1.txt", "C:\\Files\\sample1.txt", false, new ArchiveEntrySettings(null, new AesEcryptionSettings("p@s$", EncryptionMethod.AES128))); // Add file with traditional encryption to the archive archive.CreateEntry("sample2.txt", "C:\\Files\\sample2.txt", false, new ArchiveEntrySettings(encryptionSettings: new TraditionalEncryptionSettings("321"))); // Add file without encryption to the archive archive.CreateEntry("sample3.txt", "C:\\Files\\sample2.txt"); // Add folder without encryption to the archive archive.CreateEntries("C:\\Files\\MyFolder"); // save the archive archive.Save("C:\\Files\\Mixed.zip");
Ontvang een gratis licentie
U kunt de API uitproberen zonder evaluatiebeperkingen door [een gratis tijdelijke licentie][24] aan te vragen.
Conclusie
In dit artikel heb je geleerd hoe je versleutelde ZIP-bestanden maakt met C#. Je hebt ook geleerd hoe je programmatisch een met een wachtwoord beveiligd ZIP-bestand kunt maken. Bovendien heb je geleerd specifieke bestanden in de ZIP-archieven te versleutelen. Verder heb je geleerd hoe je met een wachtwoord beveiligde mappen kunt toevoegen aan ZIP-bestanden. In dit artikel wordt ook uitgelegd hoe je een ZIP-bestand kunt maken dat is versleuteld met gemengde versleutelingstechnieken met behulp van C#. U kunt meer leren over Aspose.ZIP voor .NET API met behulp van de [documentatie][25]. Neem bij onduidelijkheden gerust contact met ons op via het [forum][26].
Zie ook
- [ZIP-archieven weergeven met C#][27] [1]: https://blog.conholdate.com/wp-content/uploads/sites/27/2021/09/add-files-or-folders-to-zip-archives-using-csharp.jpg [2]: #CSharp-API-to-Create-Encrypted-ZIP-Files [3]: #Create-Password-Protected-ZIP-Files [4]: #Create-Encrypted-ZIP-Files-with-AES-Encryption [5]: #Encrypt-Folders-in-ZIP-Files [6]: #Encrypt-Specific-Files-in-ZIP-Archives [7]: #Create-Encrypted-ZIP-Files-with-Mixed-Encryption [8]: https://docs.fileformat.com/compression/zip/ [9]: https://products.aspose.com/zip/net [10]: https://releases.aspose.com/zip/net/ [11]: https://www.nuget.org/packages/Aspose.Zip/ [12]: https://apireference.aspose.com/zip/net/aspose.zip/archive [13]: https://apireference.aspose.com/zip/net/aspose.zip.saving/archiveentrysettings [14]: https://apireference.aspose.com/zip/net/aspose.zip.saving/traditionalencryptionsettings [15]: https://apireference.aspose.com/zip/net/aspose.zip.archive/createentry/methods/3 [16]: https://apireference.aspose.com/zip/net/aspose.zip.archive/save/methods/1 [17]: https://blog.conholdate.com/wp-content/uploads/sites/27/2021/09/Create-Password-Protected-ZIP-Archives.jpg [18]: https://apireference.aspose.com/zip/net/aspose.zip/archive/methods/createentry/index [19]: https://apireference.aspose.com/zip/net/aspose.zip.saving/aesecryptionsettings [20]: https://apireference.aspose.com/zip/net/aspose.zip.saving/encryptionmethod [21]: https://apireference.aspose.com/zip/net/aspose.zip.archive/createentries/methods/1 [22]: https://blog.conholdate.com/wp-content/uploads/sites/27/2021/09/Encrypt-Specific-Files-in-ZIP-Archives.jpg [23]: https://blog.conholdate.com/wp-content/uploads/sites/27/2021/09/Create-Encrypted-ZIP-Archives-with-Mixed-Encryption.jpg [24]: https://purchase.aspose.com/temporary-license [25]: https://docs.aspose.com/zip/net/ [26]: https://forum.aspose.com/c/zip/37 [27]: https://blog.conholdate.com/nl/total/render-zip-archives-using-csharp/