68 releases (2 stable)

new 1.1.1 Apr 21, 2024
0.10.0-alpha.1 May 7, 2023
0.6.4 Feb 1, 2023
0.6.3 Oct 13, 2022
0.0.3 Nov 22, 2014

#2 in Compression

Download history 315822/week @ 2024-01-05 323304/week @ 2024-01-12 361107/week @ 2024-01-19 355682/week @ 2024-01-26 359716/week @ 2024-02-02 377370/week @ 2024-02-09 356450/week @ 2024-02-16 394964/week @ 2024-02-23 413853/week @ 2024-03-01 393878/week @ 2024-03-08 406613/week @ 2024-03-15 434983/week @ 2024-03-22 410237/week @ 2024-03-29 387457/week @ 2024-04-05 410159/week @ 2024-04-12 351201/week @ 2024-04-19

1,640,377 downloads per month
Used in 1,910 crates (849 directly)

MIT license

245KB
5K SLoC

zip

Build Status Crates.io version

Documentation

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

Currently unsupported zip extensions:

  • Encryption
  • Multi-disk

Usage

With all default features:

[dependencies]
zip = "1.1.1"

Without the default features:

[dependencies]
zip = { version = "1.1.1", default-features = false }

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-miniz: Enables deflating files with the miniz_oxide library (used when compression quality is 0..=9).
  • deflate-zlib: Enables deflating files with the zlib library (used when compression quality is 0..=9).
  • deflate-zlib-ng: Enables deflating files with the zlib-ng library (used when compression quality is 0..=9). This is the fastest deflate implementation available.
  • deflate-zopfli: Enables deflating files with the zopfli library (used when compression quality is 10..=264). This is the most effective deflate implementation 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-modified zip::DateTime to and from chrono::NaiveDateTime.
  • zstd: Enables the Zstandard compression algorithm.

By default aes-crypto, deflate, deflate-zlib-ng, deflate-zopfli, bzip2, time and zstd are enabled.

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
    • While the crate is pre-1.0, this will be a change to the PATCH version.

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:

cargo install cargo-fuzz

To list fuzz targets:

cargo +nightly fuzz list

To start fuzzing zip extraction:

cargo +nightly fuzz run fuzz_read

To start fuzzing zip creation:

cargo +nightly fuzz run fuzz_write

Dependencies

~4–6.5MB
~101K SLoC