PHAR (file format)
This article relies too much on references to primary sources. (February 2018) (Learn how and when to remove this template message)
|Developed by||PHP, Davey Shafik, Greg Beaver, Marcus Börger|
|Type of format||File archive, data compression|
|Extended from||ZIP, tar|
In software, a PHAR (PHP Archive) file is a package format to enable distribution of applications and libraries by bundling many PHP code files and other resources (e.g. images, stylesheets, etc.) into a single archive file.
PHAR files may be in one of three formats: tar, and ZIP, which are compatible with their respective tooling, and a custom PHAR format. Regardless of the format used, all PHAR files use the
.phar file extension. Tar and Zip format archives may be created and unpacked using standard tar and zip utilities, while the PHAR format requires custom PHP code using the PHAR extension for PHP, or the PEAR PHP_Archive package.
Created in 2004, PHAR files were influenced by Java's JAR file format with the aim of speeding up deployment of applications via FTP. Rather than using the ZIP file format the simpler tar format was used, and the first PHAR was created using the tar command line utility as a proof of concept. On June 14, 2004 the initial PHP_Archive package was proposed to PEAR and on December 13, 2004 it was accepted unanimously.
A PHAR file allows for a Tar, Zip or PHAR formatted archive. Regardless of format, each archive contains three sections:
- Stub — A PHP file that will bootstrap the archive. The stub must contain the
__HALT_COMPILER();token, and the default stub includes the ability to run a PHAR with or without the PHP extension enabled
- Manifest — The manifest details the contents of the archive
- File Contents — The original files that are included in the archive
Additionally, the PHAR format may also include a signature for verifying PHAR integrity.
The manifest contains meta-data information about the archive, and its contents. The binary format is intended to be efficient to parse in both PHP and C. It consists of fixed length segments, in addition to pairs of length specifications followed by variable length segments. Each file has its own manifest within a segment of the global manifest. The current format is version 1.1.1.
All three formats have support for compression, however only the PHAR format supports both per-file and whole archive compression. Zip and Tar formats only support per-file and whole file compression respectively.
Executing PHAR files
Assuming the PHAR extension is enabled, all PHAR files may be executed simply by executing them with the PHP interpreter ("
php file.phar"). If the PHAR extension is not enabled, only PHAR format can be executed.
Additionally, it is possible to mark a PHAR file as executable, and to add an appropriate shebang to make the PHAR executable directly.
- "PHP 5.3 5th Anniversary: The History of PHP Archives (PHAR Files)". blog.engineyard.com. Retrieved 2016-06-16.
- "PEPr :: Details :: PHP_Archive". pear.php.net. Retrieved 2016-06-16.
- "PEPr :: Votes :: PHP_Archive". pear.php.net. Retrieved 2016-06-16.
- "PECL :: Package :: phar". pecl.php.net. Retrieved 2016-06-16.
- "PHP: News Archive - 2009". php.net. Retrieved 2016-06-16.
- "PHP: PHP 5 ChangeLog". php.net. Retrieved 2016-06-16.
- "PHP: Phar::createDefaultStub - Manual". php.net. Retrieved 2016-06-17.
- "PHP: Phar File Format - Manual". php.net. Retrieved 2016-06-17.