Getting Started with DotNetZip
This page describes how to get started using DotNetZip.
Which download to choose?
DotNetZip is free to use. You just need to download it and start using it. Different downloads of DotNetZip are available. Which one you choose depends on what you want to do.
If your goal is... | Download this... | which contains... |
To read the documentation for the library and tools | DotNetZipLib-*.chm | a compiled helpfile containing all the documentation. |
To build .NET, COM, or PowerShell apps that use the Zip library. | DotNetZipLib-DevKit-vx.x.zip | the signed DLLs for Zip and Zlib, for both the desktop and Compact Framework; the XML Documentation file for intellisense; the compiled help file (CHM); an MSI file that installs help into Visual Studio; and the License. |
To modify or view the source code for the Zip & Zlib Libraries, the setup (msi) project, or the examples. | DotNetzip-src-vx.x.x.x.zip | the VS2008 solution, containing a number of VS projects and the source code for the library and various examples that use the library. |
To distribute .NET applications that use the Zip library, or if you want to run a .NET application that depends on this library. | DotNetZipLib-Runtime-vx.x.zip | the signed DLLs for Zip and Zlib, for both the desktop and Compact Framework; and the License. This is a strict subset of the DevKit download. |
To distribute .NET applications that use the Zip library, or if you want to run a .NET application that depends on this library. | DotNetZipLib-Runtime-vx.x.msi | an .MSI version of the Runtime release, containing signed DLLs for Zip and Zlib, for both the desktop and Compact Framework; and the License. |
To create, read, or modify ZIP files from within a Windows GUI interface, or from the command line, or from within batch files. | DotNetZipUtils-v1.8.zip | a set of exe tools (command-line and GUI) that rely on the DotNetZip library, to create and manage zip files. |
To create, read, or modify ZIP files from within a Windows GUI interface, or from the command line, or from within batch files. | DotNetZipUtils-v1.8.msi | an .MSI version of the Utils download. This installs a set of exe tools (command-line and GUI) that rely on the DotNetZip library, to create and manage zip files. There's also an uninstaller. |
Which DLL to use?
When you are building an application that manipulates ZIP files, you will want to use one of the binary releases of DotNetZip. These releases include multiple distinct DLLs or assemblies. Which one should you use?
The likely answer is: Ionic.Zip.dll
That's the mainstream library, the full library, and it includes all the capability of DotNetZip. The other DLLs are reduced in various ways, to suite particular requirements.
For example, you may want a smaller library, or you want to exclude the Self-Extracting capability, or you only want the ZLIB capability. In these cases, you may want to choose a different assembly.
Here's a summary of the options.
Usage scenario | DLL |
Basic reading or writing of Zip files | Ionic.Zip.dll |
raw block or stream compression using ZLIB, DEFLATE, or GZip | Ionic.Zlib.dll |
compression using the BZip2 algorithm | Ionic.BZip2.dll |
Some combination of ZLIB/DEFLATE/GZIP compression, BZip2 compression, and reading or writing Zip files | Ionic.Zip.dll |
reading or writing Zip files on .NET Compact Framework | Ionic.Zip.CF.dll |
ZLIB/DEFLATE/GZIP compression on .NET Compact Framework | Ionic.Zlib.CF.dll |
compression using the BZip2 algorithm on .NET Compact Framework | Ionic.BZip2.CF.dll |
Some combination of ZLIB/DEFLATE/GZIP compression, BZip2 compression, and reading or writing Zip files on .NET CF | Ionic.Zip.CF.dll |
reading or writing Zip files, but never creating a self-extracting archive | Ionic.Zip.Reduced.dll |
There are also Silverlight versions of the Zlib, BZip2, and Zip libraries.
Never reference both Ionic.Zlib.dll and Ionic.Zip.dll in the same application, or both Ionic.BZip2.dll and Ionic.Zip.dll. If your application does both Zlib and Zip things, or both BZip2 and Zip things, or all three, you need only add a reference to Ionic.Zip.dll. Ionic.Zip.dll includes all the capability in Ionic.Zlib.dll and Ionic.BZip2.dll. You always need to reference only a single Ionic DLL, regardless whether you use Zlib or BZip2 or Zip or some combination.
If you use COM, then you want to reference the main DLL, Ionic.Zip.dll. If you install the DotNetZip Runtime library via the .MSI installer, the correct DLL will automatically be installed and registered for use with COM. If you don't use the .MSI installer, you will have to perform these steps yourself. Consult the documentation on using DotNetZip with COM for more information.