2024 日本 PHP 研討會

Phar::decompressFiles

(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL phar >= 2.0.0)

Phar::decompressFiles解壓縮目前 Phar 封存中的所有檔案

說明

public Phar::decompressFiles(): true

注意事項:

這個方法需要將 php.ini 設定 phar.readonly 設為 0 才能作用於 Phar 物件。否則,將會拋出 PharException 例外。

對於基於 tar 的 phar 封存檔,此方法會拋出 BadMethodCallException 例外,因為檔案格式不支援壓縮 tar 封存檔中的個別檔案。請使用 Phar::compress() 來壓縮整個基於 tar 的 phar 封存檔。

對於基於 Zip 和 phar 的 phar 封存檔,此方法會解壓縮 Phar 封存檔中的所有檔案。如果任何檔案使用 bzip2/zlib 壓縮,則必須啟用 zlibbzip2 延伸模組才能使用此功能。如同所有修改 phar 內容的功能一樣,phar.readonly INI 變數必須關閉才能成功執行。

參數

這個函式沒有參數。

傳回值

總是傳回 true

錯誤/例外

如果 phar.readonly INI 變數開啟、zlib 延伸模組不可用,或者任何檔案使用 bzip2 壓縮且 bzip2 延伸模組未啟用,則會拋出 BadMethodCallException 例外。

範例

範例 #1 Phar::decompressFiles() 範例

<?php
$p
= new Phar('/path/to/my.phar', 0, 'my.phar');
$p['myfile.txt'] = 'hi';
$p['myfile2.txt'] = 'hi';
$p->compressFiles(Phar::GZ);
foreach (
$p as $file) {
var_dump($file->getFileName());
var_dump($file->isCompressed());
var_dump($file->isCompressed(Phar::BZ2));
var_dump($file->isCompressed(Phar::GZ));
}
$p->decompressFiles();
foreach (
$p as $file) {
var_dump($file->getFileName());
var_dump($file->isCompressed());
var_dump($file->isCompressed(Phar::BZ2));
var_dump($file->isCompressed(Phar::GZ));
}
?>

上述範例會輸出:

string(10) "myfile.txt"
int(4096)
bool(false)
bool(true)
string(11) "myfile2.txt"
int(4096)
bool(false)
bool(true)
string(10) "myfile.txt"
bool(false)
bool(false)
bool(false)
string(11) "myfile2.txt"
bool(false)
bool(false)
bool(false)

另請參閱:

新增註記

使用者貢獻的註記

此頁面沒有使用者貢獻的註記。
To Top