介紹PHP開發的phar檔案概念與用法,我們知道一個php應用程式往往是由多個檔案構成的,如果能把他們集中為一個檔案來分發和運行是很方便的,這樣的列子有很多,但是在設計時主要針對PHP 的Web 環境,與JAR 歸檔不同的是Phar 歸檔可由PHP 本身處理,因此不需要使用額外的工具來創建或使用,使用php腳本就能創建或提取它。 phar是一個合成詞,由PHP 和 Archive構成,可以看出它是php歸檔檔案的意思。
phar歸檔文件有三種格式:tar歸檔、zip歸檔、phar歸檔,前兩種執行需要php安裝Phar 擴展支持,用的也比較少,這裡主要講phar歸檔格式。
phar格式歸檔檔案可以直接執行,它的產生依賴Phar擴展,由自己編寫的php腳本產生。
Phar 擴展對PHP 來說並不是一個新鮮的概念,在php5.3已經內建於php中,它最初使用PHP 編寫並被命名為PHP_Archive,然後在2005 年被添加到PEAR 庫。由於在實際中,解決這一問題的純 PHP 解決方案非常緩慢,因此 2007 年重新編寫為純 C 語言擴展,同時添加了使用 SPL 的 ArrayAccess 物件遍歷 Phar 歸檔的支援。自那時起,人們做了大量工作來改善 Phar 歸檔的表現。
Phar 擴充功能依賴php流包裝器,關於此可參考前面一篇文章PHP流Streams、包裝器wrapper概念與用法實例詳解
很多php應用都是以phar格式分發並且運行的,著名的有依賴管理:composer、單元測試:phpunit,下面我們來看看如何建立、運行、提取還原。
phar檔案的創建:
首先在php.ini修改phar.readonly這個選項,去掉前面的分號,並改值為off,由於安全原因該選項預設為on ,如果在php.ini中是停用的(值為0或off),那麼在使用者腳本中可以開啟或關閉,如果在php.ini中是開啟的,那麼使用者腳本是無法關閉的,所以這裡設定為off來展示範例。
我們來建立一個項目,在伺服器根目錄中建立項目資料夾為project,目錄內的結構如下:
file -yunek.js -yunke.css lib -lib_a.php template -msg.html index.php Lib.php
其中file資料夾有兩個內容為空的js和css文件,僅示範phar可以包含多種文件格式
lib_a.php內容如下:
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/10 * Time: 9:23 */ function show(){ echo "l am show()"; }
msg .html內容如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>phar</title> </head> <body> <?=$str; ?> </body> </html>
index.php內容如下:
<?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";
<?php /** * Created by yunke. * User: yunke * Date: 2017/2/10 * Time: 9:20 */ function yunke() { echo "l am yunke()"; }
<?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');
project yunkeBuild.php yunke.phar
<?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"; //当然仍然可以使用这样的方式去引用
如果在製作phar檔案時沒有指定別名,也可以在存根檔案裡面使用Phar::mapPhar('yunke.phar');指定
3、歸檔檔案中有一個存根文件,其實就是一段php執行程式碼,在製作歸檔時可以設置,直接執行歸檔文件時,其實就是執行它,所以它是啟動文件;在腳本中包含歸檔文件時就像包含普通php文件一樣包含它並運行,但直接以phar://的方式包含歸檔中某一個文件時不會執行存根代碼, 往往在存根文件裡面require包含要運行的其他文件,對存根文件的限制僅為以HALT_COMPILER();結束,默認的存根設計是為在沒有phar擴充時能夠運行,它提取phar檔案內容到一個臨時目錄再執行,不過從php5.3開始該擴充預設內建啟用了
4、製作的phar檔案不能被改動,因此設定檔之類的檔案需要另外放置在歸檔檔外面
5、mapPhar函數:這個函數只應該在stub存根程式碼中調用,在沒有設定歸檔別名的時候可以用來設定別名,打開一個引用映射到phar流
相信看了這些案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
相關閱讀:
#以上是PHP開發之歸檔格式phar如何使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!