编程语言您现在的位置是:首页 > 博客日志 > 编程语言

PHP 开启错误显示并设置错误报告级别

<a href='mailto:'>微wx笑</a>的头像微wx笑2019-09-04 13:43:10编程语言人已围观关键字:php

简介警告:生产环境永远都不要显示任何错误信息!显示错误(display_errors)和错误报告(error_reporting)是两回事。PHP 脚本发生错误时,可以根据设置选择是否报告这个错误(记录到错误日志


e8i编程技术_踩坑日志_进阶指南 - 无知人生

警告:生产环境永远都不要显示任何错误信息!e8i编程技术_踩坑日志_进阶指南 - 无知人生

显示错误(display_errors)和错误报告(error_reporting)是两回事。PHP 脚本发生错误时,可以根据设置选择是否报告这个错误(记录到错误日志中),如果设置中开启了 display_errors,则同时把错误信息打印到屏幕上。e8i编程技术_踩坑日志_进阶指南 - 无知人生

项目中常用的设置

switch (ENVIRONMENT)
{
    // 对于开发环境,报告所有错误,同时显示到屏幕上
    case 'development':
        error_reporting(-1);
        ini_set('display_errors', 1);
    break;

    // 对于测试和生产环境,不显示错误,5.3 以上的版本,不报告通知、废弃方法、严格这几类错误
    case 'testing':
    case 'production':
        ini_set('display_errors', 0);
        if (version_compare(PHP_VERSION, '5.3', '>='))
        {
            error_reporting(E_ALL & ~E_NOTICE & ~E_DEPRECATED & ~E_STRICT & ~E_USER_NOTICE & ~E_USER_DEPRECATED);
        }
        else
        {
            error_reporting(E_ALL & ~E_NOTICE & ~E_STRICT & ~E_USER_NOTICE);
        }
    break;

    default:
        header('HTTP/1.1 503 Service Unavailable.', TRUE, 503);
        echo 'The application environment is not set correctly.';
        exit(1); // EXIT_ERROR
}

PHP 预定义的错误常量

官网定义了所有的 错误常量,常用的有:e8i编程技术_踩坑日志_进阶指南 - 无知人生

  • E_STRICT (integer)    PHP 对代码的修改建议,以确保代码具有最佳的互操作性和向前兼容性。e8i编程技术_踩坑日志_进阶指南 - 无知人生

  • E_ALL (integer)   E_STRICT外的所有错误和警告信息。e8i编程技术_踩坑日志_进阶指南 - 无知人生

  • E_ERROR (integer) 致命的运行时错误。这类错误一般是不可恢复的情况,例如内存分配导致的问题。后果是导致脚本终止不再继续运行。e8i编程技术_踩坑日志_进阶指南 - 无知人生

  • E_WARNING (integer)   运行时警告 (非致命错误)。仅给出提示信息,但是脚本不会终止运行。e8i编程技术_踩坑日志_进阶指南 - 无知人生

  • E_PARSE (integer) 编译时语法解析错误。解析错误仅仅由分析器产生。e8i编程技术_踩坑日志_进阶指南 - 无知人生

  • E_NOTICE (integer)    运行时通知。表示脚本遇到可能会表现为错误的情况,但是在可以正常运行的脚本里面也可能会有类似的通知。e8i编程技术_踩坑日志_进阶指南 - 无知人生

在代码中开启并设置显示级别

ini_set() 函数

对于 PHP,可以通过 php.ini 文件设置各种指令。但有时候需要在脚本运行时设置指令,那就需要 ini_set() 函数了。e8i编程技术_踩坑日志_进阶指南 - 无知人生

string ini_set ( string $varname , string $newvalue )

设置指定配置选项的值。这个选项会在脚本运行时保持新的值,并在脚本结束时恢复。e8i编程技术_踩坑日志_进阶指南 - 无知人生

例如:e8i编程技术_踩坑日志_进阶指南 - 无知人生

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

error_reporting() 函数

error_reporting() 函数能够在运行时设置 error_reporting 指令。 PHP 有诸多错误级别,使用该函数可以设置在脚本运行时的级别。如果没有设置可选参数, error_reporting() 会返回当前的错误报告级别。e8i编程技术_踩坑日志_进阶指南 - 无知人生

PHP7.2 的默认值为 E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATEDe8i编程技术_踩坑日志_进阶指南 - 无知人生

在开发阶段建议启用 E_NOTICE 显示更多可能的错误。e8i编程技术_踩坑日志_进阶指南 - 无知人生

<?php

// 关闭所有PHP错误报告,相当于 ini_set('error_reporting', 0);
error_reporting(0);

error_reporting(E_ERROR | E_WARNING | E_PARSE);

// 报告 E_NOTICE  (报告未初始化的变量或捕获变量名的错误拼写)
error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);

// 除了 E_NOTICE,报告其他所有错误
error_reporting(E_ALL ^ E_NOTICE);

// 报告所有 PHP 错误 (参见 changelog)
error_reporting(E_ALL);

// 报告所有 PHP 错误
error_reporting(-1);

// 和 error_reporting(E_ALL); 一样
ini_set('error_reporting', E_ALL);

修改 php.ini 配置文件

error_reporting = E_ALL # 报告所有错误
display_errors = On # 显示错误

转自:https://blog.csdn.net/kikajack/article/details/80713388e8i编程技术_踩坑日志_进阶指南 - 无知人生

本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。e8i编程技术_踩坑日志_进阶指南 - 无知人生

本文由 微wx笑 创作,采用 CC BY-NC 4.0 许可协议。 非商业性使用可自由转载、引用、甚至修改,但需署名作者且注明出处。

很赞哦! () 有话说 ()

站点信息

  • 建站时间:2018-10-24
  • 服务期限阿里云ECS 2027年到期
  • 主题模板:基于《今夕何夕》修改
  • 文章统计:210篇
  • 文章评论:15条
  • 文章阅读:2818次
  • 文章点赞:1026次
  • 微信公众号:扫描二维码,关注我们
  • 二维码-微信公众号-微wx笑