摘要:至,有同样的行为。表示关闭所有错误报告表示显示二函数说明设置应该报告何种错误说明函数能够在运行时设置指令。后果是导致脚本终止不再继续运行。初始化启动过程中发生的警告非致命错误。用户产少的警告信息。出外的所有错误和警告信息。
错误报告级别:指定了在什么情况下,脚本代码中的错误(这里的错误是广义的错误,包括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 之中,只有"|", "~", "!", "^" 和 "&" 会正确解析。
如果不关闭E_NOTICE,则未初始化的变量会显示在页面:
在php_error_log 中可以看出:
如果给脚本加上这段代码,就不会爆出这样的提示:
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);
调试脚本:
EOF; echo $str;
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/23209.html
摘要:当程序开发完成,成为正式产品时,我们希望将没有预测到的报错信息记录到错误日志中,而不是将这些报错信息展示给用户,因为用户极有可能利用这些暴露出脚本路径数据库信息或其他的报错信息进行一些破坏性的黑客行动。 程序报错总是在所难免,尽管我们书写代码时已经格外小心。 在开发php程序时,我们希望遇到php报错,可以第一时间展示给我们,以便于调试。当程序开发完成,成为正式产品时,我们希望将没有预...
摘要:设置时间脚本执行时间设置最大执行内存设置内存获取使用内存设置与客户机断开是否会终止脚本的执行,直至有输出任务为止设置默认时区与获取默认时区设置跨域访问限制跨域文件设置报错信息开启报错,开发环境关闭报错,生产环境 1.设置时间脚本执行时间 set_time_limit(0); 2.设置最大执行内存 ini_set(memory_limit,1024M);//设置内存 memory_get...
摘要:异常处理上节解读源码一自动加载看完了自动加载部分,根据代码执行顺序,的行注册错误和异常处理机制加载惯例配置文件下面的加载配置文件不用说,现在重点看一下异常处理。博客链接解读源码二异常处理和请求生命周期 异常处理 上节解读 thinkphp5 源码(一):自动加载看完了自动加载部分,根据代码执行顺序,base.php的59-64行 // 注册错误和异常处理机制 hinkError::r...
阅读 3573·2019-08-30 15:55
阅读 1372·2019-08-29 16:20
阅读 3655·2019-08-29 12:42
阅读 2660·2019-08-26 10:35
阅读 1009·2019-08-26 10:23
阅读 3404·2019-08-23 18:32
阅读 896·2019-08-23 18:32
阅读 2891·2019-08-23 14:55