Eine PHP-Anwendung besteht oft aus mehreren Dateien. Es ist sehr praktisch, wenn sie in einer Datei zusammengefasst und ausgeführt werden können. Es gibt viele solcher Beispiele, wie zum Beispiel das Installationsprogramm auf dem Windows-Betriebssystem, eine JQuery-Bibliothek usw. Um dies zu erreichen, verwendet PHP das Phar-Dokumentdateiformat. Dieses Konzept ist vom Java-JAR abgeleitet, wurde jedoch hauptsächlich für entwickelt
Die Webumgebung von PHP kann im Gegensatz zu JAR-Archiven Phar-Archive sein
Wird nativ gehandhabt, sodass zum Erstellen oder Verwenden keine zusätzlichen Tools erforderlich sind. Verwenden Sie einfach ein PHP-Skript zum Erstellen oder Extrahieren. phar ist ein zusammengesetztes Wort aus PHP und
Archivzusammensetzung, Sie können sehen, dass es sich um eine PHP-Archivdatei handelt.
Es gibt drei Formate von Phar-Archivdateien: TAR-Archiv, Zip-Archiv und Phar-Archiv. Die ersten beiden Ausführungsarten erfordern die Installation der Phar-Erweiterungsunterstützung und werden hier hauptsächlich über das Phar-Archivformat gesprochen.
Die Archivdatei im Phar-Format kann direkt ausgeführt werden. Ihre Generierung basiert auf der Phar-Erweiterung und wird von einem von Ihnen selbst geschriebenen PHP-Skript generiert.
Die Phar-Erweiterung ist kein neues Konzept für PHP. Sie wurde ursprünglich in PHP 5.3 geschrieben und benannt PHP_Archive wurde dann 2005 zur PEAR-Bibliothek hinzugefügt. Da reine PHP-Lösungen für dieses Problem in der Praxis sehr langsam sind, 2007 Als reine C-Spracherweiterung umgeschrieben und ArrayAccess-Objektdurchquerung mit SPL Phar hinzugefügt Archivierungsunterstützung. Seitdem wurde viel daran gearbeitet, die Leistung der Phar-Archive zu verbessern.
Die Phar-Erweiterung hängt vom PHP-Stream-Wrapper ab. Weitere Informationen finden Sie im vorherigen Artikel „PHP-Streams und Wrapper-Wrapper-Konzepte und Anwendungsbeispiele“
Viele PHP-Anwendungen werden im Phar-Format verteilt und ausgeführt. Zu den bekanntesten gehören das Abhängigkeitsmanagement: Composer und Unit Testing: PHPUnit.
Erstellung der Phar-Datei:
Ändern Sie zunächst die Option phar.readonly in php.ini, entfernen Sie das vorangehende Semikolon und ändern Sie den Wert auf „off“. Aus Sicherheitsgründen ist diese Option standardmäßig auf „on“ gesetzt (der Wert ist 0 oder off). ), dann kann es im Benutzerskript aktiviert oder deaktiviert werden. Wenn es in php.ini aktiviert ist, kann das Benutzerskript nicht deaktiviert werden, daher ist es hier auf „Aus“ gesetzt, um das Beispiel zu zeigen.
Erstellen wir ein Projekt. Erstellen Sie einen Projektordner im Stammverzeichnis des Servers. Die Struktur im Verzeichnis ist wie folgt:
file -yunek.js -yunke.css lib -lib_a.php template -msg.html index.php Lib.php
Der Dateiordner enthält zwei JS- und CSS-Dateien mit leerem Inhalt. Dies zeigt nur, dass Phar mehrere Dateiformate enthalten kann
Der Inhalt von lib_a.php lautet wie folgt:
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/10 * Time: 9:23 */ function show(){ echo "l am show()"; }
Der Inhalt von msg.html lautet wie folgt:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>phar</title> </head> <body> <?=$str; ?> </body> </html>
Der Inhalt von index.php lautet wie folgt:
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/10 * Time: 9:17 */ require "lib/lib_a.php"; show(); $str = isset($_GET["str"]) ? $_GET["str"] : "hello world"; include "template/msg.html";
Der Inhalt von Lib.php lautet wie folgt:
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/10 * Time: 9:20 */ function yunke() { echo "l am yunke()"; }
Die Projektdatei ist fertig und kann nun erstellt werden. Erstellen Sie nun eine yunkeBuild.php im selben Verzeichnis wie der Projektordner, der zum Generieren von Dateien im Phar-Format verwendet wird:
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/10 * Time: 9:36 */ //产生一个yunke.phar文件 $phar = new Phar('yunke.phar', 0, 'yunke.phar'); // 添加project里面的所有文件到yunke.phar归档文件 $phar->buildFromDirectory(dirname(__FILE__) . '/project'); //设置执行时的入口文件,第一个用于命令行,第二个用于浏览器访问,这里都设置为index.php $phar->setDefaultStub('index.php', 'index.php');
Greifen Sie dann im Browser auf diese yunkeBuild.php-Datei zu. Zu diesem Zeitpunkt lautet die Server-Stammverzeichnisstruktur wie folgt:
project yunkeBuild.php yunke.phar
Dies ist der einfachste Prozess zum Generieren einer Phar-Archivdatei. Weitere Informationen finden Sie auf der offiziellen Website. Bitte beachten Sie, dass die Verwendung der Phar-Archivdatei
Verwendung von Phar-Archivdateien: Wir erstellen eine index.php-Datei im Stammverzeichnis des Servers, um zu demonstrieren, wie die oben erstellte Phar-Datei verwendet wird. Der Inhalt lautet wie folgt:<?php /** * Created by yunke. * User: yunke * Date: 2017/2/8 * Time: 9:33 */ require "yunke.phar"; require "phar://yunke.phar/Lib.php"; yunke();
require "project/index.php";
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/9 * Time: 19:02 */ $phar = new Phar('composer.phar'); $phar->extractTo('composer'); //提取一份原项目文件 $phar->convertToData(Phar::ZIP); //另外再提取一份,和上行二选一即可
$phar = new Phar('lib/yunke.phar', 0); $phar->setAlias ( "yun.phar");
<?php require "lib/yunke.phar"; require "phar://yun.phar/Lib.php"; //使用别名访问归档文件 require "phar://lib/yunke.phar/Lib.php"; //当然仍然可以使用这样的方式去引用
3. Die Archivdatei enthält eine Stub-Datei, bei der es sich tatsächlich um einen Teil des PHP-Ausführungscodes handelt. Sie kann beim Erstellen des Archivs festgelegt werden, es handelt sich also um eine Startdatei ; Wenn die Archivdatei in das Skript eingebunden wird, verhält es sich wie bei einer normalen PHP-Datei. Der Stub-Code wird jedoch nicht ausgeführt, wenn Sie eine Datei mit phar:// direkt in das Archiv einbinden. Die Stub-Datei erfordert häufig die Ausführung anderer Dateien. Die Einschränkung für die Stub-Datei besteht nur darin, mit __HALT_COMPILER(); zu enden. Der Standard-Stub ist für die Ausführung ohne die Phar-Datei konzipiert Verzeichnis und dann ausführen, aber ab PHP5.3 ist die Erweiterung standardmäßig aktiviert
4. Die erstellte Phar-Datei kann nicht geändert werden, daher müssen Dateien wie Konfigurationsdateien außerhalb der Archivdatei abgelegt werden
5. MapPhar-Funktion: Diese Funktion sollte nur im Stub-Code aufgerufen werden. Wenn der Archivalias nicht festgelegt ist, kann sie zum Festlegen des Alias und zum Öffnen einer Referenz verwendet werden, die dem Phar-Stream zugeordnet ist.
Verwandte Empfehlungen:
So verwenden Sie das Archivformat phar für die PHP-Entwicklung
So verwenden Sie das Phar-Paket in PHP
Ausführliches Tutorial zur Verwendung des Phar-Pakets in PHP
Das obige ist der detaillierte Inhalt vonKonzept und Verwendung der Phar-Datei im PHP-Entwicklungsarchivformat. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!