Вопрос

Я использую PHP 5.3 на Debian и в соответствии с php -m «Фар» загружен.

Но выполнение php pyrus.phar или же php pyrus.phar config-show приводит к отсутствию вывода вообще.

В чем может быть проблема?

debian:~# php -v
PHP 5.3.5-1 with Suhosin-Patch (cli) (built: Feb 19 2011 01:57:59)
Copyright (c) 1997-2009 The PHP Group
Zend Engine v2.3.0, Copyright (c) 1998-2010 Zend Technologies
    with Xdebug v2.1.0, Copyright (c) 2002-2010, by Derick Rethans
    with Suhosin v0.9.32.1, Copyright (c) 2007-2010, by SektionEins GmbH

php -i дает мне:

[...]

Phar

Phar: PHP Archive support => enabled
Phar EXT version => 2.0.1
Phar API version => 1.1.1
SVN revision => $Revision: 305584 $
Phar-based phar archives => enabled
Tar-based phar archives => enabled
ZIP-based phar archives => enabled
gzip compression => enabled
bzip2 compression => enabled
OpenSSL support => enabled


Phar based on pear/PHP_Archive, original concept by Davey Shafik.
Phar fully realized by Gregory Beaver and Marcus Boerger.
Portions of tar implementation Copyright (c) 2003-2009 Tim Kientzle.
Directive => Local Value => Master Value
phar.cache_list => no value => no value
phar.readonly => On => On
phar.require_hash => On => On

[...]

Что меня смущает, так это то, что Libxml2 должен быть доступен по умолчанию для PHP> 5.3.1, но PHP -M только перечисляет Libxml. Хотя PHP -я даст мне:

libXML support => active
libXML Compiled Version => 2.7.8
libXML Loaded Version => 20708
libXML streams => enabled
Это было полезно?

Решение

Нашел это :)

Похоже, Debian установит PHP -версию с патчем Suhosin. Мой собственный выход PHP -V покажет следующее:

web01:/home/berry# php -v
PHP 5.3.5-1 with Suhosin-Patch (cli) (built: Feb 19 2011 01:57:59) 
Copyright (c) 1997-2009 The PHP Group
Zend Engine v2.3.0, Copyright (c) 1998-2010 Zend Technologies
    with Suhosin v0.9.32.1, Copyright (c) 2007-2010, by SektionEins GmbH

Теперь кажется, что Сухозин вызывает эту проблему: это не позволяет выполнять файл PHAR. Если вы посмотрите в /var/log/user.log, вы должны увидеть запись следующим образом:

web01:/home/berry# tail /var/log/user.log | grep pyrus
Mar 23 11:27:50 web01 suhosin[17463]: ALERT - Include filename ('phar:///home/berry/pyrus.phar/PEAR2_Pyrus-2.0.0a2/php/PEAR2/Pyrus/ScriptFrontend/Commands.php') is an URL that is not allowed (attacker 'REMOTE_ADDR not set', file '/home/berry/pyrus.phar', line 40)

Поскольку мы выполняем это только на CLI, добавление строки ниже в /etc/php5/cli/conf.d/phar.ini должно решить эту проблему, это было для меня.

suhosin.executor.include.whitelist="phar"

Удачи :)

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top