zip
Info
A zip library for rust which supports reading and writing of simple ZIP files. Formerly hosted at https://github.com/zip-rs/zip.
Supported compression formats:
- stored (i.e. none)
- deflate
- deflate64 (decompression only)
- bzip2
- zstd
- lzma (decompression only)
Currently unsupported zip extensions:
- Multi-disk
Features
The features available are:
aes-crypto: Enables decryption of files which were encrypted with AES. Supports AE-1 and AE-2 methods.deflate: Enables decompressing the deflate compression algorithm, which is the default for zip files.deflate-zlib: Enables deflating files with thezliblibrary (used when compression quality is 0..=9).deflate-zlib-ng: Enables deflating files with thezlib-nglibrary (used when compression quality is 0..=9). This is the fastestdeflateimplementation available.deflate-zopfli: Enables deflating files with thezopflilibrary (used when compression quality is 10..=264). This is the most effectivedeflateimplementation available.deflate64: Enables the deflate64 compression algorithm. Only decompression is supported.lzma: Enables the LZMA compression algorithm. Only decompression is supported.bzip2: Enables the BZip2 compression algorithm.time: Enables features using the time crate.chrono: Enables converting last-modifiedzip::DateTimeto and fromchrono::NaiveDateTime.zstd: Enables the Zstandard compression algorithm.
By default aes-crypto, deflate, deflate-zlib-ng, deflate-zopfli, bzip2, time and zstd are enabled.
The following feature flags are deprecated:
deflate-miniz: Useflate2's default backend for compression. Currently the same asdeflate.
MSRV
Our current Minimum Supported Rust Version is 1.70. When adding features, we will follow these guidelines:
- We will always support the latest four minor Rust versions. This gives you a 6 month window to upgrade your compiler.
- Any change to the MSRV will be accompanied with a minor version bump.
Examples
See the examples directory for:
- How to write a file to a zip.
- How to write a directory of files to a zip (using walkdir).
- How to extract a zip file.
- How to extract a single file from a zip.
- How to read a zip from the standard input.
Fuzzing
Fuzzing support is through cargo fuzz. To install cargo fuzz:
To list fuzz targets:
To start fuzzing zip extraction:
To start fuzzing zip creation: