Heim  >  Artikel  >  Backend-Entwicklung  >  Wie PHP Phar-Dateien verwaltet

Wie PHP Phar-Dateien verwaltet

php中世界最好的语言
php中世界最好的语言Original
2018-04-11 09:47:403810Durchsuche

Dieses Mal zeige ich Ihnen, wie Sie Phar-Dateien mit PHP bedienen. Was sind die Vorsichtsmaßnahmen für den Betrieb von Phar-Dateien mit PHP?

Dieser Artikel beschreibt das Konzept und die Verwendung der Phar-Datei im Archivformat in der PHP-Entwicklung. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

Eine PHP-Anwendung besteht oft aus mehreren Dateien. Es ist sehr praktisch, sie in einer Datei zu verteilen und auszuführen. Es gibt viele Beispiele dafür, 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 von Javas 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.

Die offizielle Website-Dokumentation von phar finden Sie unter http://php.net/manual/zh/book.phar.php. Dieses Dokument kann als Ergänzung zur offiziellen Website-Dokumentation angesehen werden

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 verwendet Phar-Archivformat.

Die Archivdatei im Phar-Format kann direkt ausgeführt werden. Ihre Generierung hängt von der Phar-Erweiterung ab 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 Jahr als reine C-Spracherweiterung umgeschrieben, außerdem ArrayAccess mit SPL Object Traversal Phar hinzugefügt Archivierungsunterstützung. Seitdem wurde viel daran gearbeitet, die Leistung der Phar-Archive zu verbessern.

Die Phar-Erweiterung basiert auf dem PHP-Stream-Wrapper. 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, Unit Test : PHPUnit.

Phar-Dateierstellung:

Ä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(&#39;yunke.phar&#39;, 0, &#39;yunke.phar&#39;);
// 添加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 wird die Server-Root--Verzeichnisstruktur wie folgt erstellt:

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();
Wenn in der Datei index.php nur die erste Zeile vorhanden ist, fügen Sie den folgenden Code genau so hinzu, wie wenn Sie keine Archivdatei verwenden:

require "project/index.php";

如果没有第二行,那么第三行的yunke()将提示未定义,所以可见require一个phar文件时并不是导入了里面所有的文件,而只是导入了入口执行文件而已,但在实际项目中往往在这个入口文件里导入其他需要使用的文件,在本例中入口执行文件为project/index.php

phar文件的提取还原:

我们有时候会好奇phar里面包含的文件源码,这个时候就需要将phar文件还原,如果只是看一看的话可以使用一些ide工具,比如phpstorm 10就能直接打开它,如果需要修改那么就需要提取操作了,为了演示,我们下载一个composer.phar放在服务器目录,在根目录建立一个get.php文件,内容如下:

<?php
/**
 * Created by yunke.
 * User: yunke
 * Date: 2017/2/9
 * Time: 19:02
 */
$phar = new Phar(&#39;composer.phar&#39;);
$phar->extractTo('composer'); //提取一份原项目文件
$phar->convertToData(Phar::ZIP); //另外再提取一份,和上行二选一即可

用浏览器访问这个文件,即可提取出来,以上列子展示了两种提取方式:第二行将建立一个composer目录,并将提取出来的内容放入,第三行将产生一个composer.zip文件,解压即可得到提取还原的项目文件。

补充:

1、在部署phar文件到生产服务器时需要调整服务器的配置,避免当访问时浏览器直接下载phar文件

2、可以为归档设置别名,别名保存在归档文件中永久保存,它可以用一个简短的名字引用归档,而不管归档文件在文件系统中存储在那里,设置别名:

$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"; //当然仍然可以使用这样的方式去引用

如果在制作phar文件时没有指定别名,也可以在存根文件里面使用Phar::mapPhar('yunke.phar');指定

3、归档文件中有一个存根文件,其实就是一段php执行代码,在制作归档时可以设置,直接执行归档文件时,其实就是执行它,所以它是启动文件;在脚本中包含归档文件时就像包含普通php文件一样包含它并运行,但直接以phar://的方式包含归档中某一个文件时不会执行存根代码, 往往在存根文件里面require包含要运行的其他文件,对存根文件的限制仅为以HALT_COMPILER();结束,默认的存根设计是为在没有phar扩展时能够运行,它提取phar文件内容到一个临时目录再执行,不过从php5.3开始该扩展默认内置启用了

4、制作的phar文件不能被改动,因此配置文件之类的文件需要另外放置在归档文件外面

5、mapPhar函数:这个函数只应该在stub存根代码中调用,在没有设置归档别名的时候可以用来设置别名,打开一个引用映射到phar流

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

如何用swoole与websocket开发一个聊天室

在PHP中怎样实现微信退款功能

Das obige ist der detaillierte Inhalt vonWie PHP Phar-Dateien verwaltet. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn