Использование Phar-архивов
PHP Manual

Использование Phar-архивов: классы Phar и PharData

Класс Phar поддерживает чтение и обработку Phar-архивов, а также итерацию через унаследованную функциональность класса RecursiveDirectoryIterator. Благодаря поддержке интерфейса ArrayAccess, доступ к файлам внутри Phar-архива может быть получен, как если бы они были частью ассоциативного массива.

Класс PharData расширяет класс Phar и позволяет создавать и изменять неисполняемые tar- и zip-архивы данных даже в том случае, если параметр phar.readonly=1 в php.ini. Фактически функции PharData::setAlias() и PharData::setStub() отключены, поскольку концепция псевдонима и заглушки является уникальной для исполняемых phar-архивов.

Важно отметить, что при создании Phar-архива в конструктор объекта Phar должен быть передан полный путь. Попытки инициализации объекта Phar с относительными путями потерпят неудачу.

Предположим, что $p — объект Phar, инициализированный, как показано ниже:

<?php
$p 
= new Phar('/путь/к/myphar.phar'0'myphar.phar');
?>

Пустой Phar-архив будет создан в /путь/к/myphar.phar, или, если файл /path/to/myphar.phar уже существует, он будет открыт повторно. Использование myphar.phar показывает концепцию псевдонима, который может быть использован для указания на /путь/к/myphar.phar в URL'ах, подобно тому, как показано ниже:

<?php
// эти два вызова file_get_contents() равнозначны в том случае, если
// /путь/к/myphar.phar имеет явно заданный псевдоним "myphar.phar"
// в своем манифесте, или если phar был инициализирован созданием объекта Phar,
// как показано в предыдущем примере
$f file_get_contents('phar:///путь/к/myphar.phar/whatever.txt');
$f file_get_contents('phar://myphar.phar/whatever.txt');
?>

С только что созданным объектом $p класса Phar возможно следующее:

Кроме того, использование объекта Phar является единственным способом получить доступ к метаданным архива (через Phar::getMetadata()) и единственным способом установить или получить заглушку Phar-архива через Phar::getStub() и Phar::setStub(). К тому же, работать со сжатием целого Phar-архива можно только используя класс Phar.

Полный перечень функционала объекта Phar задокументирован ниже.

Класс PharFileInfo расширяет класс SplFileInfo и добавляет несколько методов для работы с деталями, присущими файлам, которые содержатся в Phar-архиве, такими как работа со сжатием и метаданными.


Использование Phar-архивов
PHP Manual