Как можно ослабить ограничение PHP open_basedir?
open_basedir ограничивает файлы, которые могут быть открыты PHP в дереве каталогов.
Я храню несколько библиотек классов и файлов конфигурации вне моего корневого веб-каталога. Таким образом, веб-сервер не делает их общедоступными. Однако, когда я пытаюсь включить их из своего приложения, я получаю ошибку ограничения open_basedir, например:
Предупреждение: realpath() [function.realpath]: действует ограничение open_basedir. Файл (/var/www/vhosts/domain.tld/zend/application) находится вне допустимых путей: (/var/www/vhosts/domain.tld/httpdocs:/tmp) в /var/www/vhosts/domain.tld/httpdocs/index.php в строке 5
Мой веб-корень здесь:
/var/www/vhosts/domain.tld/httpdocs
Мои библиотеки и каталог конфигурации находятся здесь:
/var/www/vhosts/domain.tld/zend
Как лучше всего обойти ограничение open_basedir, чтобы дерево каталогов в папке домена стало доступно моему приложению? У меня есть несколько доменов, с которыми я хочу сделать это, и я также явно опасаюсь создавать уязвимости безопасности.
Примечание: я использую CentOS, Apache, Plesk, и у меня есть root-доступ по ssh к серверу. И хотя это не относится к Zend Framework напрямую, я использую его в этом случае. Итак, вот включение из начальной загрузки Зенда:
define('APPLICATION_PATH', realpath(dirname(__FILE__) . '/../zend/application/'));
set_include_path(APPLICATION_PATH . '/../zend/library' . PATH_SEPARATOR . get_include_path());
3 ответа
Вы также можете легко сделать это для каждого каталога, используя конфигурационный файл Apache (предполагается, что это ваш веб-сервер) (например, httpd.conf).
<Directory /var/www/vhosts/domain.tld/httpdocs>
php_admin_value open_basedir "/var/www/vhosts/domain.tld/httpdocs:/var/www/vhosts/domain.tld/zend"
</Directory>
Вы также можете полностью снять ограничение с
<Directory /var/www/vhosts/domain.tld/httpdocs>
php_admin_value open_basedir none
</Directory>
Добавьте пути, к которым вам нужен доступ (/var/www/vhosts/domain.tld/zend) к вашей директиве open_basedir (вы можете указать несколько путей, используя разделитель пути ':' или ';' в окнах)
обратите внимание, что значения в open_basedir являются префиксами, что означает, что все, что находится в /var/www/vhosts/domain.tld/zend, будет доступно
В Parallels Plesk Panel (например, 1 и 1) вы можете сделать это в настройках панели PHP:
Вот: