brokencube / zipstream64
ZipStream is a library for dynamically streaming large dynamic zip files from PHP without writing to the disk at all on the server.
Installs: 7 505
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 1
Forks: 2
Open Issues: 0
Requires
- php: >= 5.6
- php-64bit: *
- psr/http-message: 1.0
Requires (Dev)
- phpunit/phpunit: 4.3.*
README
The enhancements in this fork of https://github.com/maennchen/ZipStream-PHP have now been brought back into that project as of v1.0.0 - However, if you need PHP 5.6 / 7.0 (Which you shouldn't - those PHP versions are about to die!), this repo is still available.
ZipStream64
Streaming Zips with 64bit large file support
Please see the file LICENSE.md for licensing and warranty information (Standard MIT Licence).
Installation
Easiest installation is via Composer:
"require": { "brokencube/zipstream64": "0.1.*" }
Overview
A fast and simple streaming zip file downloader for PHP. Here's a simple example:
use brokencube\ZipStream\ZipStream; # Autoload the dependencies require 'vendor/autoload.php'; # create a new zipstream object $zip = new ZipStream('example.zip'); # create a file named 'hello.txt' $zip->addFile('hello.txt', 'This is the contents of hello.txt'); # add a file named 'image.jpg' from a local file 'path/to/image.jpg' $zip->addFileFromPath('some_image.jpg', 'path/to/image.jpg'); # add a file named 'goodbye.txt' from an open stream resource $fp = tmpfile(); fwrite($fp, 'The quick brown fox jumped over the lazy dog.'); $zip->addFileFromStream('goodbye.txt', $fp); fclose($fp); # add a file named 'farewell.txt' from a PSR7 stream (e.g. Guzzle / AWS) $amazonS3 = new Sdk()->createS3(); $file = $amazonS3->getObject(['Bucket' => 'bucket.name', 'Key' => 'path/to/farewell.txt']); $zip->addFileFromPsr7Stream('farewell.txt', $file['Body']); # finish the zip stream $zip->finish();
Requirements
- 64-bit PHP version 5.6 or newer.
Contributors
This project leans very heavily on previous work of the following projects:
95% of kudos for this project goes to them!
Some Caveats
64bit Zips don't work properly with macOS's default Zip library (i.e. used by the built-in unarchive). If you need >4GB Zips on mac, your users will need to use 3rd party software to unzip them. If your zip is going to be smaller, you can turn off 64bit support by calling:
$zip = new ZipStream('example.zip', [ZipStream::OPTION_USE_ZIP64 => false]);