• 技术文章 >后端开发 >PHP问题

    php调用自己的方法报错500

    (*-*)浩(*-*)浩2019-09-17 11:44:00原创1098
    对于http请求报错状态码为500,通常解释是:表示服务器遇到错误,无法完成请求(即服务器内部错误),但具体问题还要具体分析。

    PHP程序语法错误导致

    场景一:我们项目设置有报警监控(定时每隔10分钟访问一下网站的一个固定链接),曾经有段时间,每天都会收到两三次报500错误的邮件,但当自己再手动访问时却访问正常…(推荐学习:PHP编程从入门到精通

    这应该是最常见的错误了,语法错误也能很快复现,只要把报错信息暴露出来即可根据问题立马解决。

    如果是在本地或测试环境,通常我们是这么处理的,在程序入口中设置输出报错信息即可:

    //error_reporting设置应该报告的错误,下面表示除了 E_NOTICE,报告其他所有错误
    error_reporting(E_ALL ^ E_NOTICE);
    //输出错误
    ini_set('display_errors', 1);

    但在线上环境的话,因为用户都在用,不可能允许我们就那么赤裸裸的打印错误,怎么办呢?可以在程序入口文件中设置将错误输出到日志文件中,具体代码如下:

    error_reporting(E_ALL ^ E_NOTICE);
    //禁止把错误输出到页面
    ini_set('display_errors', 0);
    //设置错误信息输出到文件
    ini_set('log_errors', 1);
    
    //指定错误日志文件名
    $error_dir = '/logs/err/';
    $error_file = $error_dir . date('Ymd').'.log';
    //目录不存在就创建
    if (!is_dir($error_dir)){
        mkdir($error_dir, 0777, true);
    }
    //文件不存在就创建之
    if(!file_exists($error_file)){
        $fp = fopen($error_file, 'w+');
        if($fp){
            fclose($fp);
        }
    }
    
    //设置错误输出文件
    ini_set("error_log", $error_file);
    
    //程序正常执行逻辑......

    刚才说的场景一问题,后来我们按照上面输出到log的方式输出才发现的,是因为mysql连接异常断开而程序继续执行(连接mysql时正常,但当调用具体查询方法时报错,记得好像是在使用方法mysqli_real_escape_string()的地方)导致的fatal级报错,最终才顺利修复了。

    以上就是php调用自己的方法报错500的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:php
    上一篇:php加密的作用 下一篇:php中mysqli_query函数的作用
    线上培训班

    相关文章推荐

    • php协程是什么• php字符串转数组• php项目有哪些结构• php字符串转int

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网