php error_reporting()关闭报错

php error_reporting()关闭报错

大家好,又见面了,我是全栈君。

错误报告级别:指定了在什么情况下,脚本代码中的错误(这里的错误是广义的错误,包括
E_NOTICE注意、
E_WARNING警告、
E_ERROR致命错误等)会以错误报告的形式输出。

一、常用设置说明

error_reporting(-1); 表示显示所有PHP错误报告,包括将来PHP加入的新的错误级别。 至PHP5.4,E_ALL有同样的行为。

error_reporting(0); 表示关闭所有PHP错误报告

error_reporting(7); 表示显示 E_ERROR(1) | E_WARING(2) | E_PARSE(4) == (1+2+4)

二、error_reporting函数说明

error_reporting — 设置应该报告何种 PHP 错误

说明

int error_reporting ([ int $level ] )

error_reporting() 函数能够在运行时设置 error_reporting 指令。 PHP 有诸多错误级别,使用该函数可以设置在脚本运行时的级别。 如果没有设置可选参数 level, error_reporting() 仅会返回当前的错误报告级别。

参数 level

新的 error_reporting 级别。 可以是一个位掩码也可以是一个已命名的常量。 强烈建议使用已命名的常量,以确保兼容将来的版本。 由于错误级别的添加、整数取值范围的增加, 较久的基于整数的错误级别不会总是和预期的表现一致。
可用的错误级别常量及其实际含义描述在了 predefined constants 中。

值 常量 说明 备注
1 E_ERROR (integer) 致命的运行时错误。这类错误一般是不可恢复的情况,例如内存分配导致的问题。后果是导致脚本终止不再继续运行。 
2 E_WARNING (integer) 运行时警告 (非致命错误)。仅给出提示信息,但是脚本不会终止运行。 
4 E_PARSE (integer) 编译时语法解析错误。解析错误仅仅由分析器产生。 
8 E_NOTICE (integer) 运行时通知。表示脚本遇到可能会表现为错误的情况,但是在可以正常运行的脚本里面也可能会有类似的通知。 
16 E_CORE_ERROR (integer) 在PHP初始化启动过程中发生的致命错误。该错误类似 E_ERROR,但是是由PHP引擎核心产生的。 since PHP 4
32 E_CORE_WARNING (integer) PHP初始化启动过程中发生的警告 (非致命错误) 。类似 E_WARNING,但是是由PHP引擎核心产生的。 since PHP 4
64 E_COMPILE_ERROR (integer) 致命编译时错误。类似E_ERROR, 但是是由Zend脚本引擎产生的。 since PHP 4
128 E_COMPILE_WARNING (integer) 编译时警告 (非致命错误)。类似 E_WARNING,但是是由Zend脚本引擎产生的。 since PHP 4
256 E_USER_ERROR (integer) 用户产生的错误信息。类似 E_ERROR, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的。 since PHP 4
512 E_USER_WARNING (integer) 用户产生的警告信息。类似 E_WARNING, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的。 since PHP 4
1024 E_USER_NOTICE (integer) 用户产生的通知信息。类似 E_NOTICE, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的。 since PHP 4
2048 E_STRICT (integer) 启用 PHP 对代码的修改建议,以确保代码具有最佳的互操作性和向前兼容性。 since PHP 5
4096 E_RECOVERABLE_ERROR (integer) 可被捕捉的致命错误。 它表示发生了一个可能非常危险的错误,但是还没有导致PHP引擎处于不稳定的状态。 如果该错误没有被用户自定义句柄捕获 (参见 set_error_handler()),将成为一个 E_ERROR 从而脚本会终止运行。 since PHP 5.2.0
8192 E_DEPRECATED (integer) 运行时通知。启用后将会对在未来版本中可能无法正常工作的代码给出警告。 since PHP 5.3.0
16384 E_USER_DEPRECATED (integer) 用户产少的警告信息。 类似 E_DEPRECATED, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的。 since PHP 5.3.0
30719 E_ALL (integer) E_STRICT出外的所有错误和警告信息。 30719 in PHP 5.3.x, 6143 in PHP 5.2.x, 2047 previously

上面的值(数值或者符号)用于建立一个二进制位掩码,来制定要报告的错误信息。可以使用按位运算符来组合这些值或者屏蔽某些类型的错误。请注意,在 php.ini 之中,只有’|’, ‘~’, ‘!’, ‘^’ 和 ‘&’ 会正确解析。

<?php
 
// 关闭所有PHP错误报告
error_reporting(0);
 
// 报告简单的运行错误
error_reporting(E_ERROR | E_WARNING | E_PARSE);
error_reporting(7);
 
// 报告 E_NOTICE 也挺好 (报告未初始化的变量或者捕获变量名的错误拼写)
error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);
 
// 除了 E_NOTICE,报告其他所有错误
// 这是在 php.ini 里的默认设置
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);
 
?>

如果不关闭E_NOTICE,则未初始化的变量会显示在页面:

clipboard.png

在php_error_log 中可以看出:

clipboard.png

如果给脚本加上这段代码,就不会爆出这样的提示:

error_reporting(E_ALL ^ E_NOTICE);

三、设置 php.ini

有时候,PHP代码在调试的时候,有错误,不提示是一件很忧伤的事,难道你指望自己猜出问题所在么?当然不行,就算在最页面最开始执行了 error_reporting(E_ALL),发现还是没有输出错误,其实原因就是在php.ini里面将display_errors关闭了。可以在php.ini里面将display_errors配置为On,然后重启php-fpm如果服务器上既有测试项目,又有线上项目,那么还是不要开启,以防别人利用你的错误,而攻击你

只需要再需要测试的项目里面加上即可

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

四、在PHP脚本打印错误信息

ini_set('display_errors',1);            //错误信息
ini_set('display_startup_errors',1);    //php启动错误信息
error_reporting(-1);                    //打印出所有的 错误信息

项目中打印错误信息:

// 错误信息
@ini_set('display_errors',1);
error_reporting(E_ALL & ~ (E_STRICT | E_NOTICE | E_WARNING));

判断某个进程是否有运行:

// 判断程序是否有启动
define('runcode', 1);

    $handle = popen("ps -ef | grep redis 2>&1", 'r');
        $cmd_cont = '';
        while(!feof($handle)) {
            $buffer = fgets($handle);
            $cmd_cont .= $buffer;
        }
        pclose($handle);

dump($cmd_cont);

  

调试脚本:

<?php

/**
 * ---------------------------------
 * 调试系统-在线编辑器
 * ---------------------------------
 * @desc 如需使用该在线编辑器,则需要设置常量:define('run', 1);
 * @author Corwien
 * @version 2017-07
 * ---------------------------------
 */

// 加载配置文件
define('IN_EB', true);
define('ROOT_PATH', __DIR__ . "/");

// 错误信息
@ini_set('display_errors', 1);
error_reporting(E_ALL & ~ (E_STRICT | E_NOTICE | E_WARNING));

// 初始化
$text = isset($_REQUEST['text']) ? $_REQUEST['text'] : '';
preg_match("/define\('run', 1\);/", $text) && eval($text);
// if($text == '') $text = "define('runcode', 1);";

  


转载:https://segmentfault.com/a/1190000010113821
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/112116.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • windows 设置定时锁屏

    windows 设置定时锁屏设置间隔指定时间电脑自动锁屏CreateTime–2017年7月3日10:16:14Author:Marydon参考地址:电脑爱好者杂志举例:实现每间隔45分钟,电脑自动锁屏实现思路:  第一步:编写锁屏命令;  第二步:制定计划。实践:  1.编写锁屏命令    新建一个txt文件,重命名为:lockScreen(名字随意)–>打开该文件添…

  • Linux下 文件类型不同颜色的含义

    Linux下 文件类型不同颜色的含义

  • spring boot activiti7常见问题「建议收藏」

    spring boot activiti7常见问题「建议收藏」问题:通过historyService查询报错,table不存在。原因:activiti7默认没有开启数据库历史记录。解决办法: activiti: db-history-used:true //启动数据库历史记录 history-level:audit //默认级别问题:database-schema-update配置级别…

    2022年10月20日
  • EBS安装完成后,对数据库相关配置的改动

    EBS安装完成后,对数据库相关配置的改动

    2021年11月14日
  • linux centos7下源码 tar安装mysql5.7.30或mysql5.7.22 图文详解「建议收藏」

    linux centos7下源码 tar安装mysql5.7.30或mysql5.7.22 图文详解「建议收藏」之前用的rpm安装的每次安装都是最新的,,,导致每次版本不统一。。。现在用tar包安装5.7.22和5.7.20一样的5.7.20之后的和之前的版本还是有点不一样的官网地址https://dev.mysql.com/downloads/mysql/https://dev.mysql.com/doc/refman/5.7/en/environment-variables.html…

  • PCI,PCI-X,PCI-E

    PCI,PCI-X,PCI-EPCI-X是PCI总线的扩展架构,PCI-X频率不像PCI那样固定,而是可以随着设备的变化而变化的。PCI-X采用64位PCI总线(PCI為32bit),可以支持66,100,133MHz这些频率。而在未来,可能将提供更多的频率支持。PCI-X标准的提出主要面向服务器I/O结构。PCI-X的设计目标在于提高CPU与外设之间的传输速度,能使服务器的I/O速度提高两倍。与原来的PCI标准开发商不同的是

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号