我怎样才能放松PHP的open_basedir限制?

isu*_*dor 21 php apache security

open_basedir限制了PHP在目录树中可以打开的文件.

我在我的Web根目录之外存储了几个类库和配置文件.这样,Web服务器不会使它们可公开访问.但是,当我尝试从我的应用程序中包含它们时,我得到一个open_basedir限制错误,如下所示:

警告:realpath()[function.realpath]:open_basedir限制生效.文件(/var/www/vhosts/domain.tld/zend/application)不在/ var/www /中的允许路径中:(/ var/www/vhosts/domain.tld/httpdocs:/ tmp)第5行的vhosts/domain.tld/httpdocs/index.php

我的网站根目录在这里:

/var/www/vhosts/domain.tld/httpdocs
Run Code Online (Sandbox Code Playgroud)

我的库和配置目录在这里:

/var/www/vhosts/domain.tld/zend
Run Code Online (Sandbox Code Playgroud)

放宽open_basedir限制的最佳解决方法是什么,以便域文件夹下的目录树可用于我的应用程序?我有很多域名需要我这样做,而且我显然也很担心创建安全漏洞.

注意:我使用的是CentOS,Apache,Plesk,我对服务器有root ssh访问权限.虽然这不直接适用于Zend Framework,但我在这个实例中使用它.所以这里是来自Zend的bootstrap的包含:

define('APPLICATION_PATH', realpath(dirname(__FILE__) . '/../zend/application/'));
set_include_path(APPLICATION_PATH . '/../zend/library' . PATH_SEPARATOR . get_include_path());
Run Code Online (Sandbox Code Playgroud)

Tom*_*igh 21

您还可以使用Apache每个目录的基础上做到这一点很容易(假设这是您的Web服务器)配置文件(如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>
Run Code Online (Sandbox Code Playgroud)

你也可以完全删除限制

<Directory /var/www/vhosts/domain.tld/httpdocs>
php_admin_value open_basedir none
</Directory>
Run Code Online (Sandbox Code Playgroud)

  • 如果操作正在运行plesk,他需要稍微特别一点:http://www.toosweettobesour.com/2008/02/02/plesk-open_basedir-workaround/ (6认同)