TP5项目在lnmp环境上线出现500错误

在windows下没问题,但是上传到服务器后访问接口出现500错误

用的是lnmp的环境,文件上传后把所有权限都打开,都显示

HTTP ERROR 500的错误,服务器内部错误


该网页无法正常运作

mz.kechangfu.cn 目前无法处理此请求。
HTTP ERROR 500

    1
    2
    3
    4
    5
    6



在入口文件index.php中加入

error_reporting(E_ALL);
ini_set('display_errors', '1');

    1
    2

来打印所有错误信息

代码打印出


Warning: require(): open_basedir restriction in effect. File(/home/wwwroot/mz.kchangfu.cn/thinkphp/start.php) is not within the allowed path(s): (/home/wwwroot/mz.kchangfu.cn/public/:/tmp/:/proc/) in /home/wwwroot/mz.kchangfu.cn/public/index.php on line 22

Warning: require(/home/wwwroot/mz.kchangfu.cn/thinkphp/start.php): failed to open stream: Operation not permitted in /home/wwwroot/mz.kchangfu.cn/public/index.php on line 22

Fatal error: require(): Failed opening required '/home/wwwroot/mz.kchangfu.cn/public/../thinkphp/start.php' (include_path='.:/usr/local/php/lib/php') in /home/wwwroot/mz.kchangfu.cn/public/index.php on line 22

    1
    2
    3
    4
    5
    6

三、分析错误内容

  查看问题描述以及资料,发现是php open_basedir 配置的问题,php不能引入其授权目录上级及其以上的文件,默认配置在php.ini(/usr/local/php/etc/php.ini),但是我的open_basedir 并没有配置,默认被注释了。

#在php.ini
open_basedir =  //没有打开也是空的
#在.user.ini
open_basedir=/home/wwwroot/mz/public:/tmp/:/proc/
#在fastcgi.conf
fastcgi_param PHP_ADMIN_VALUE "open_basedir=$document_root/:/tmp/:/proc/";

    1
    2
    3
    4
    5
    6

只需把
fastcgi_param PHP_ADMIN_VALUE "open_basedir=$document_root/:/tmp/:/proc/";
改成

`fastcgi_param PHP_ADMIN_VALUE "open_basedir=/home/wwwroot/:/tmp/:/proc/";`

    1

解决

open_basedir 配置项的文件权限问题,如果遇到了这样的情况,把php.ini 服务器nginx、Apache的配置文件都检查下。

posted on 2019-03-09 16:35  王俊儒2018  阅读(205)  评论(0编辑  收藏  举报

导航