【PHP 配置文件中与错误相关的选项 】

选项 描述
error_reporting 设置错误报告的级别
display_errors 是否显示错误
log_errors 设置是否将错误信息记录到日志或者 error_log 中
error_log   设置脚本错误将记录到的文件
log_errors_max_len 设置 log_errors 的最大字节数
ignore_repeated_errors 是否忽略重复的错误信息
ignore_repeated_source 是否忽略重复错误消息的来源
track_errors 如果开启此选项,最后一个错误将永久保存在$php_errormsg 中

error_reporting

例如:

error_reporting = E_ALL 

代表错误级别是所有错误。还可以设置为该语句上文中提到的所有错误级别,。

注:php 5.4以上版本中,E_STRICT 就属于 E_ALL 中的一部分。

这些错误级别可以单独使用,也可以配合位运算符结合使用。

【例】显示所有错误,但是不显示 notice,php.ini 中的 error_reporting 应该设置为:

error_reporting = E_ALL & ~E_NOTICE

display_error

开发环境需要打开(display_errors = On),生产环境(线上)需要关闭(diaplay_errors = Off)。

【设置错误级别】

① 通过 PHP 配置文件设置(以上都是这种方式)

② 通过 error_reporting() 函数设置(动态设置)

【例1】得到当前错误级别的位掩码

<?php
echo error_reporting();

输出:

30719

(对应的 error_reporting = E_ALL)

【例2】设置错误级别—— 显示所有错误

<?php
error_reporting(E_ALL);

【例3】不显示通知级别的错误

<?php
error_reporting(E_ALL & ~E_NOTICE);
echo $dee;

输出:

什么都不输出。

【例4】屏蔽所有错误 —— 部署到线上时,可以通过这种方法设置错误级别,防止信息泄漏给用户

<?php
error_reporting(0);
echo dee(); //致命级别的错误

输出:

什么都不输出 —— 即使是致命级别的错误(Fatal 级别)也不现实,但解析错误(语法检测阶段)仍然会显示,如例5

【例5】

<?php
error_reporting(0);
echo dee()

输出:

( ! ) Parse error: syntax error, unexpected $end, expecting ',' or ';' in D:\practise\php\Error\error1.php on line 3

【例6】显示所有错误

<?php
error_reporting(-1);
echo dee();

输出:

( ! ) Fatal error: Call to undefined function dee() in D:\practise\php\Error\error1.php on line 3

③ 通过 ini_set() 函数运行时设置

【例1】不显示所有错误

<?php
ini_set('error_reporting', 0);
echo dee();

输出:

什么都不输出。

或者

<?php
ini_set('display_errors', 0);
echo dee();

也能达到不显示所有错误的效果。

【例2】显示所有错误

<?php
ini_set('error_reporting', -1);
echo dee();

输出:

( ! ) Fatal error: Call to undefined function dee() in D:\practise\php\Error\error1.php on line 3

【常用设置】

在php.ini 中可以对 error_reporting 进行如下设置,以屏蔽我们认为不是错误的提示:

error_reporting = E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED

或者在发送 header 之前,把所有的内容输出到内存缓冲中(output buffering)。

【附】① 位运算符

② php 5.4 以上版本官方推荐使用 mysqli 代替 mysql

PHP 错误与异常 笔记与总结(3)PHP 配置文件(php.ini)中与错误相关的选项 与 设置错误级别的更多相关文章

  1. PHP 错误与异常 笔记与总结(10)错误处理器测试

    关联文件:myErrorHandler.php (上一篇) 先测试通知级别的错误的自定义处理: testErrorHandler.php <?php require_once 'myErrorH ...

  2. PHP 错误与异常 笔记与总结(7)将错误日志以邮件方式发送

    当系统发生了很严重的问题,需要立刻发送给管理员.可以通过 error_log() 将错误以邮件形式发送到邮箱. 在 php.ini 中设置: sendmail_from = 472323087@qq. ...

  3. PHP 错误与异常 笔记与总结(4)通过 trigger_error 触发 PHP 错误

    [错误抑制符@] 除了 php.ini 中 error_reporting 和 display_errors 的设置.error_reporting() 函数.ini_set() 函数 外,还可以使用 ...

  4. PHP 错误与异常 笔记与总结(8)自定义错误处理函数 set_error_handler()

    通过 Set_error_handler() 函数设置用户自定义的错误处理函数. 步骤: ① 创建错误处理函数 ② 设置不同级别调用函数 ③ Set_error_handler() 函数制定接管错误处 ...

  5. PHP 错误与异常 笔记与总结(6)将错误日志保存在系统日志中

    [将错误记录到系统日志中] 在 php.ini 中将 error_log 设置为: error_log = syslog 或者在运行时使用 ini_set() 函数设置. [例1] <?php ...

  6. PHP 错误与异常 笔记与总结(5)配置文件中与错误日志相关的选项 && 将错误记录到指定的文件中

    [记录错误(生产环境)] php.ini: ① 开启 / 关闭 错误日志功能 log_errors = On ② 设置 log_errors 的最大字节数 log_errors_max_len = 其 ...

  7. PHP 错误与异常 笔记与总结(2)错误(Fatal)

    (接上) d.Fatal error 致命级别的错误 —— 程序终止执行 [例7]调用一个未定义的方法 <?php echo md6('dee'); echo 'continue'; 输出: ( ...

  8. 配置完php.ini中的扩展库后,重启apache出现错误1067

    网上有很多解决办法,比如更改环境变量,重装apache等等,但没有一个是符合我的.最后发现只是犯了一个低级错误,因为是第一次配置php.ini中的扩展库,忘记配置扩展库的路径. 解决办法:需要先加上扩 ...

  9. PHP 错误与异常 笔记与总结(12 )异常

    ① 异常的概念:异常和错误的区别 PHP 部分借鉴了 C++ 和 JAVA 中的异常处理机制.PHP 中的异常是指 程序运行和预期不太一致,与错误是两个不同的概念. ② 异常的语法结构 [例1] &l ...

随机推荐

  1. Balance(poj 1837)

    题意:一个天平上有C个挂钩,第i个挂钩的位置为C[i],C[i] < 0表示该挂钩在原点的左边,C[i] > 0表示该挂钩在原点的右边:然后给出G个钩码的重量,问有多少种挂法使得天平保持平 ...

  2. hdu 1018:Big Number(水题)

    Big Number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  3. hdu 1806 rmq

    找到一个区间内出现最多的数的次数 10 3 //10个数字三次询问 -1 -1 1 1 1 1 3 10 10 10 2 3 1 10 5 10 0 143 #include<cstdio> ...

  4. 使用ASP.NET 5开发AngularJS应用

    今天推荐的是一个系列文章,讲述了如何使用ASP.NET 5来开发AngularJS应用,一共7篇文章. 在Visual Studio 2015中由于优化了项目结构,优化了前端JS框架的引用方式,所以开 ...

  5. vb.net三层实现登录例子

    看三层已经很长时间了,中间有经过了期末考试.回家等等琐事,寒假开学的我已经回想不起什么事三层了,经过了三四天的重新复习,再加上查看各期师哥师姐的博客,终于,自己完成了C#视频中的登录小例子,下面就和大 ...

  6. Rain on your Parade

    Rain on your Parade Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 655350/165535 K (Java/Ot ...

  7. CC150 - 11.5

    Question: Given a sorted array of strings which is interspersed with empty strings, write a method t ...

  8. 使 SortList 实现重复键排序

    SortList 默认对按Key来排序,且Key值不能重复,但有时可能需要用有重复值的Key来排序,以下是实现方式: 1.对强类型:以float为例 #region 使SortList能对重复键排序 ...

  9. ERROR 2013 (HY000): Lost connection to MySQL server at 'waiting for initial communication packet', system error: 2

    ERROR (HY000): Lost connection to MySQL server at 'waiting for initial communication packet', system ...

  10. CentoS 下报的 Requires: perl(:MODULE_COMPAT_5.8.8)

    yum error requires: libtcmalloc.so.4 rpm -Uvh http://ceph.com/rpm-cuttlefish/el6/x86_64/ceph-release ...