最近在使用阿里云主机的时候,发现用PHPEXCEL导出数据表时,系统报出以下错误:
Warning: realpath() [function.realpath]: open_basedir restriction in effect. File(/tmp) is not within the allowed path(s): (/data/home/byu2599880001/:/usr/home/byu2599880001/:/data/home/tmp/:/usr/home/tmp/:/var/www/disablesite/) in /data/home/byu2599880001/htdocs/peixun/PHPExcel/Shared/File.php on line 136
在网上查询,有些是让修改PHP.INI文件,但一般用主机类的用户都没有权限进行设置,后来在网上查询,是可以通过修改PHPExcel/Shared/File.php文件进行解决。
查找到以下代码函数function sys_get_temp_dir()
public static function sys_get_temp_dir()
{
// sys_get_temp_dir is only available since PHP 5.2.1
// http://php.net/manual/en/function.sys-get-temp-dir.php#94119
if (!function_exists('sys_get_temp_dir')) {
if ($temp = getenv('TMP')) {
if (file_exists($temp)) {
return realpath($temp);
}
}
if ($temp = getenv('TEMP')) {
if (file_exists($temp)) {
return realpath($temp);
}
}
if ($temp = getenv('TMPDIR')) {
if (file_exists($temp)) {
return realpath($temp);
}
}
// trick for creating a file in system's temporary dir
// without knowing the path of the system's temporary dir
$temp = tempnam(__FILE__, '');
if (file_exists($temp)) {
unlink($temp);
return realpath(dirname($temp));
}
return null;
}
// use ordinary built-in PHP function
//There should be no problem with the 5.2.4 Suhosin realpath() bug, because this line should only
//be called if we're running 5.2.1 or earlier
return realpath(sys_get_temp_dir());
}
将以上代码替换为以下代码:
public static function sys_get_temp_dir()
{
// use upload-directory when defined to make it running on
// environments having very restricted open_basedir configs
if (ini_get('upload_tmp_dir') !== false) {
if ($temp = ini_get('upload_tmp_dir')) {
if (file_exists($temp)) {
return realpath($temp);
}
}
}
// sys_get_temp_dir is only available since PHP 5.2.1
// http://php.net/manual/en/function.sys-get-temp-dir.php#94119
if (!function_exists('sys_get_temp_dir')) {
if ($temp = getenv('TMP')) {
if (file_exists($temp)) {
return realpath($temp);
}
if (($temp != '') && file_exists($temp)) {
return realpath($temp);
}
}
if ($temp = getenv('TEMP')) {
if (file_exists($temp)) {
return realpath($temp);
}
}
}
}
只需要将函数里的程序代码替换一下即可,函数名不用动。替换后问题解决。