2015-02-20 15:38:09 +01:00
|
|
|
PHPArchive - Pure PHP ZIP and TAR handling
|
|
|
|
==========================================
|
|
|
|
|
|
|
|
This library allows to handle new ZIP and TAR archives without the need for any special PHP extensions (gz and bzip are
|
|
|
|
needed for compression). It can create new files or extract existing ones.
|
|
|
|
|
|
|
|
To keep things simple, the modification (adding or removing files) of existing archives is not supported.
|
|
|
|
|
2015-02-25 20:51:35 +01:00
|
|
|
[![Build Status](https://travis-ci.org/splitbrain/php-archive.svg)](https://travis-ci.org/splitbrain/php-archive)
|
|
|
|
|
2015-02-20 15:38:09 +01:00
|
|
|
Install
|
|
|
|
-------
|
|
|
|
|
|
|
|
Use composer:
|
|
|
|
|
2015-02-20 15:43:24 +01:00
|
|
|
```php composer.phar require splitbrain/php-archive```
|
2015-02-20 15:38:09 +01:00
|
|
|
|
|
|
|
Usage
|
|
|
|
-----
|
|
|
|
|
2015-06-29 21:45:00 +02:00
|
|
|
The usage for the Zip and Tar classes are basically the same. Here are some
|
2015-08-05 21:07:59 +02:00
|
|
|
examples for working with TARs to get you started.
|
|
|
|
|
|
|
|
Check the [API docs](https://splitbrain.github.io/php-archive/) for more
|
|
|
|
info.
|
|
|
|
|
2015-02-20 15:38:09 +01:00
|
|
|
|
|
|
|
```php
|
2015-06-29 21:45:00 +02:00
|
|
|
require_once 'vendor/autoload.php';
|
2015-02-20 15:38:09 +01:00
|
|
|
use splitbrain\PHPArchive\Tar;
|
|
|
|
|
2015-06-29 21:45:00 +02:00
|
|
|
// To list the contents of an existing TAR archive, open() it and use
|
|
|
|
// contents() on it:
|
2015-02-20 15:38:09 +01:00
|
|
|
$tar = new Tar();
|
|
|
|
$tar->open('myfile.tgz');
|
|
|
|
$toc = $tar->contents();
|
|
|
|
print_r($toc); // array of FileInfo objects
|
|
|
|
|
2015-06-29 21:45:00 +02:00
|
|
|
// To extract the contents of an existing TAR archive, open() it and use
|
|
|
|
// extract() on it:
|
2015-02-20 15:38:09 +01:00
|
|
|
$tar = new Tar();
|
|
|
|
$tar->open('myfile.tgz');
|
|
|
|
$tar->extract('/tmp');
|
|
|
|
|
2015-06-29 21:45:00 +02:00
|
|
|
// To create a new TAR archive directly on the filesystem (low memory
|
|
|
|
// requirements), create() it:
|
2015-02-20 15:38:09 +01:00
|
|
|
$tar = new Tar();
|
|
|
|
$tar->create('myfile.tgz');
|
|
|
|
$tar->addFile(...);
|
|
|
|
$tar->addData(...);
|
|
|
|
...
|
|
|
|
$tar->close();
|
|
|
|
|
2015-06-29 21:45:00 +02:00
|
|
|
// To create a TAR archive directly in memory, create() it, add*()
|
|
|
|
// files and then either save() or getArchive() it:
|
2015-02-20 15:38:09 +01:00
|
|
|
$tar = new Tar();
|
2015-08-12 11:46:20 +02:00
|
|
|
$tar->setCompression(9, Archive::COMPRESS_BZIP);
|
2015-02-20 15:38:09 +01:00
|
|
|
$tar->create();
|
|
|
|
$tar->addFile(...);
|
|
|
|
$tar->addData(...);
|
|
|
|
...
|
2015-08-12 11:46:20 +02:00
|
|
|
$tar->save('myfile.tbz'); // compresses and saves it
|
|
|
|
echo $tar->getArchive(); // compresses and returns it
|
2015-02-20 15:38:09 +01:00
|
|
|
```
|
|
|
|
|
2015-06-29 21:45:00 +02:00
|
|
|
Differences between Tar and Zip: Tars are compressed as a whole, while Zips compress each file individually. Therefore
|
|
|
|
you can call ```setCompression``` before each ```addFile()``` and ```addData()``` function call.
|
2015-02-20 15:38:09 +01:00
|
|
|
|
|
|
|
The FileInfo class can be used to specify additional info like ownership or permissions when adding a file to
|
2015-08-05 21:07:59 +02:00
|
|
|
an archive.
|