Test in production without watermarks.
Works wherever you need it to.
Get 30 days of fully functional product.
Have it up and running in minutes.
Full access to our support engineering team during your product trial
ZIP files are files that contain one or more compressed files or folders using the ZIP format. It is a common way of compressing and archiving multiple files or folders into a single file. They can reduce the size of the data, save disk space, and make it easier to transfer files over the internet. In this article, you will learn how to work with ZIP files in C# using the IronZIP library. You will see how to create, read, extract, and update ZIP files programmatically, as well as how to use various features of IronZIP, such as encryption, password protection, and compression levels. By the end of this article, you will be able to use IronZIP to handle ZIP files in your C# applications with ease.
IronZIP is a powerful and versatile C# ZIP archive library that allows you to create, read, and extract ZIP files programmatically. It supports various archive formats, such as ZIP, TAR, GZIP, and BZIP2. It also supports password protection, encryption, and compression levels. IronZIP is compatible with .NET 8, 7, 6, Core, Standard, and Framework.
IronZIP can help you handle various use cases and benefits of working with ZIP files, such as:
Before writing the code, you need to install the IronZIP NuGet Package in your C# project. IronZIP is a popular compression library available via NuGet.
To install IronZIP, you can use the NuGet Package Manager Console in Visual Studio. Simply run the following command:
Install-Package IronZip
Alternatively, you can download the package directly from the official IronZIP website. Once installed, you can get started by adding the following namespace to the top of your C# code.
using IronZip;
using IronZip;
You can easily create ZIP files in a folder using IronZIP. The following code will zip all the files from the specified directory.
using System;
using System.IO;
using IronZip;
class Program
{
static void Main(string[] args)
{
// Get all files from the specified directory
string[] fileArray = Directory.GetFiles(@"D:\Docs\");
// Create a new ZIP archive
using (var archive = new IronZipArchive())
{
// Iterate through each file and add it to the archive
foreach (var file in fileArray)
{
archive.Add(file); // Add files to the ZIP
}
// Save the archive to a file
archive.SaveAs("myZipFile.zip");
}
}
}
using System;
using System.IO;
using IronZip;
class Program
{
static void Main(string[] args)
{
// Get all files from the specified directory
string[] fileArray = Directory.GetFiles(@"D:\Docs\");
// Create a new ZIP archive
using (var archive = new IronZipArchive())
{
// Iterate through each file and add it to the archive
foreach (var file in fileArray)
{
archive.Add(file); // Add files to the ZIP
}
// Save the archive to a file
archive.SaveAs("myZipFile.zip");
}
}
}
The above C# code uses the IronZIP library to compress all the files into a single ZIP file. The code does the following:
fileArray
and assigns it the result of the Directory.GetFiles
method, passing the path of the directory ("D:\Docs") as a parameter. This method returns an array of strings containing the full names of all the files in the specified directory.IronZipArchive
class, which represents a ZIP archive in memory. The instance is assigned to a variable named archive
and is wrapped in a using
statement, which ensures that the ZIP archive is disposed of when the code block ends.fileArray
array using a foreach
loop, and for each file, it calls the Add
method of the archive
object, passing the file name as a parameter. This method adds a new entry to the ZIP archive, with the same name and content as the file.SaveAs
method of the archive
object, passing the name of the ZIP file (“myZipFile.zip”) as a parameter. This method saves the ZIP archive to a file in the current file system.In this way, you can easily create new ZIP archives using just a few lines of code.
Output is as follows:
IronZIP provides an easy method to create password-protected ZIP files. The following code sample will compress files and create a new ZIP file with a password.
using System;
using System.IO;
using IronZip;
class Program
{
static void Main(string[] args)
{
// Get all files from the specified directory
string[] fileArray = Directory.GetFiles(@"D:\Docs\");
// Create a new ZIP archive
using (var archive = new IronZipArchive())
{
// Iterate through each file and add it to the archive
foreach (var file in fileArray)
{
archive.Add(file); // Add files to the ZIP
}
// Set Password and Encryption Method
archive.Encrypt("myPa55word", EncryptionMethods.AES256);
// Save the archive to a file
archive.SaveAs("myZipFile.zip");
}
}
}
using System;
using System.IO;
using IronZip;
class Program
{
static void Main(string[] args)
{
// Get all files from the specified directory
string[] fileArray = Directory.GetFiles(@"D:\Docs\");
// Create a new ZIP archive
using (var archive = new IronZipArchive())
{
// Iterate through each file and add it to the archive
foreach (var file in fileArray)
{
archive.Add(file); // Add files to the ZIP
}
// Set Password and Encryption Method
archive.Encrypt("myPa55word", EncryptionMethods.AES256);
// Save the archive to a file
archive.SaveAs("myZipFile.zip");
}
}
}
The line archive.Encrypt("myPa55word", EncryptionMethods.AES256);
sets a password ("myPa55word") for a ZIP archive using IronZIP. It enhances security by applying AES-256 encryption to the archive, ensuring that only users with the correct password can access its contents. This feature is valuable for protecting sensitive data during storage or transfer within C# applications. You need to pass the specified mode of the Encryption algorithm in the second parameter.
The file is encrypted as shown below.
We have seen the demonstration of creating a ZIP file by looping through the directories from the specified path. Now, let's move toward the example of unzipping files.
IronZIP provides a method to extract files from a ZIP archive in C#. The following code sample will extract the compressed file within a ZIP archive.
using IronZip;
class Program
{
static void Main(string[] args)
{
// Extract all files from the ZIP archive to the specified directory
IronZipArchive.ExtractArchiveToDirectory("myZipFile.zip", "myExtractedFiles");
}
}
using IronZip;
class Program
{
static void Main(string[] args)
{
// Extract all files from the ZIP archive to the specified directory
IronZipArchive.ExtractArchiveToDirectory("myZipFile.zip", "myExtractedFiles");
}
}
The code IronZipArchive.ExtractArchiveToDirectory("myZipFile.zip", "myExtractedFiles");
uses IronZIP to extract all files from "myZipFile.zip" and places them in the "myExtractedFiles" directory. This concise method simplifies the process of extracting ZIP archives in C#, providing a convenient solution for file extraction tasks.
Output is as follows:
IronZIP also provides a method to extract password-protected ZIP files. The following code will use the IronZIP method to extract all the existing files and directories from the specified ZIP file.
using IronZip;
class Program
{
static void Main(string[] args)
{
// Extract all files from the password-protected ZIP archive to the specified directory
IronZipArchive.ExtractArchiveToDirectory("myZipFile.zip", "myExtractedFiles", "myPa55word");
}
}
using IronZip;
class Program
{
static void Main(string[] args)
{
// Extract all files from the password-protected ZIP archive to the specified directory
IronZipArchive.ExtractArchiveToDirectory("myZipFile.zip", "myExtractedFiles", "myPa55word");
}
}
The ExtractArchiveToDirectory
method of the IronZipArchive
class extracts all the entries from a ZIP archive to a specified directory. It passes three arguments to the method: the path of the ZIP file (“myZipFile.zip”), the path of the destination directory (“myExtractedFiles”), and the password of the ZIP file (“myPa55word”).
In this way, you can easily extract password-protected ZIP files.
IronZIP provides methods to access the existing archive and view all the entries present in the file.
using System;
using System.Collections.Generic;
using IronZip;
class Program
{
static void Main(string[] args)
{
// Open an existing ZIP archive with a password
using (var archive = new IronZipArchive("myZipFile.zip", "myPa55word"))
{
// Get entries list
List<string> names = archive.GetArchiveEntryNames();
// Iterate through each entry name and print it
foreach (string name in names)
{
Console.WriteLine(name);
}
}
}
}
using System;
using System.Collections.Generic;
using IronZip;
class Program
{
static void Main(string[] args)
{
// Open an existing ZIP archive with a password
using (var archive = new IronZipArchive("myZipFile.zip", "myPa55word"))
{
// Get entries list
List<string> names = archive.GetArchiveEntryNames();
// Iterate through each entry name and print it
foreach (string name in names)
{
Console.WriteLine(name);
}
}
}
}
The provided C# code uses IronZIP to create a secure IronZipArchive
instance by loading a ZIP file named "myZipFile.zip" with the password "myPa55word". Don't pass the password parameter if the file is not encrypted. It then retrieves and prints the list of entry names (file and folder names) within the encrypted ZIP archive.
The GetArchiveEntryNames
method gathers the entry names, and a foreach
loop outputs each name to the console. This demonstrates how IronZIP enables secure access and retrieval of entry information from password-protected ZIP archives in a concise manner.
In conclusion, IronZIP proves to be a robust and versatile C# library for working with ZIP files. Its capabilities extend beyond basic compression and extraction, offering features such as password protection, encryption, and compatibility with various archive formats. Whether you're creating backup systems, managing email attachments, or downloading files from the web, IronZIP streamlines these tasks with simplicity and efficiency.
By integrating IronZIP into your C# applications, you gain a powerful tool for handling ZIP files, enhancing data security, and optimizing file transfer processes. You can benefit from a free trial as needed.
IronZIP is a powerful and versatile C# ZIP archive library that allows you to create, read, and extract ZIP files programmatically. It supports various archive formats and features such as password protection, encryption, and compression levels.
You can install IronZIP via the NuGet Package Manager Console in Visual Studio by running the command 'Install-Package IronZip'. Alternatively, you can download the package from the official IronZIP website.
To create a ZIP file using IronZIP, you can use the IronZipArchive class to iterate through files and add them to a new ZIP archive, then save it using the SaveAs method.
Yes, IronZIP can create password-protected ZIP files by using the Encrypt method with a specified password and encryption method such as AES256.
You can extract files from a ZIP archive using the IronZipArchive.ExtractArchiveToDirectory method, specifying the ZIP file and destination directory.
To extract files from a password-protected ZIP archive, use the ExtractArchiveToDirectory method and provide the password alongside the ZIP file and destination directory.
You can access an existing ZIP archive by creating an IronZipArchive instance with the ZIP file and optional password, then retrieve entry names using the GetArchiveEntryNames method.
IronZIP streamlines tasks like creating backup systems, managing email attachments, and downloading files from the web by offering features such as encryption, password protection, and support for various archive formats.
Yes, IronZIP is compatible with .NET 8, 7, 6, Core, Standard, and Framework, providing flexibility across different C# projects.
You can benefit from a free trial of IronZIP by visiting the licensing section on the IronZIP website.