Phar::mount
(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL phar >= 2.0.0)
Phar::mount — 外部のパスあるいはファイルを phar アーカイブ内に仮想的にマウントする
説明
final public static function Phar::mount(
string $pharPath,
string $externalPath):
void
パラメータ
pharPath
-
マウントする場所として使用する phar アーカイブ内のパス。
これは phar アーカイブ内の相対パスでなければならず、また、
既に存在するパスを指定することはできません。
externalPath
-
phar アーカイブ内にマウントしたい外部ファイルあるいはディレクトリのパスあるいは URL。
例
例1 Phar::mount() の例
次の例は、外部の設定ファイルをまるでそれが
phar アーカイブ内のパス上にあるかのように扱うものです。
<?php
$configuration = simplexml_load_string(file_get_contents(
Phar::running(false) . '/config.xml'));
?>
<?php
// まずは、抽象化した config.xml
// と実際のディスク上のファイルを関連づけます
Phar::mount('phar://config.xml', '/home/example/config.xml');
// アプリケーションを実行します
include '/path/to/archive.phar';
?>
もうひとつの方法として、コードを phar アーカイブのスタブ内に置くというものがあります。
これは、ユーザーが設定ファイルを指定しなかった場合にデフォルトの設定ファイルを使用する例です。
<?php
// まずは、抽象化した config.xml
// と実際のディスク上のファイルを関連づけます
if (defined('EXTERNAL_CONFIG')) {
Phar::mount('config.xml', EXTERNAL_CONFIG);
if (file_exists(__DIR__ . '/extra_config.xml')) {
Phar::mount('extra.xml', __DIR__ . '/extra_config.xml');
}
} else {
Phar::mount('config.xml', 'phar://' . __FILE__ . '/default_config.xml');
Phar::mount('extra.xml', 'phar://' . __FILE__ . '/default_extra.xml');
}
// アプリケーションを実行します
include 'phar://' . __FILE__ . '/index.php';
__HALT_COMPILER();
?>
...and the code externally to load this phar archive:
<?php
define('EXTERNAL_CONFIG', '/home/example/config.xml');
// アプリケーションを実行します
include '/path/to/archive.phar';
?>