• 前端PHP入门-032-异常处理-应用级别


    禁止显示错误

    在php.ini配置文件中。我们可以控制php的错误显示状态。

    php.ini中有一个专门的配置项:

    display_errors
    这个选项设置是否将错误信息输出到网页,或者对用户隐藏而不显示。
    这个值的状态为 on 或者 off ,也可以设值为 1 或者 0

    • display_error的值设为0或者off则不在页面中显示错误,
    • 设为1或者on则显示错误信息。

    问题:如果没有修改服务器php.ini的状态权限怎么办?

    可以使用ini_set

    1. <?php
    2. ini_set('display_errors' , 0 );
    3. ?>

    上面的代码也相当于修改了php.ini中display_errors的值。不过,仅仅在当前php代码中生效

    问题:想取得php.ini的配置项状态怎么办?

    可以使用ini_get(参数项) 得到参数的值。

    演示例子:

    1. <?php
    2. echo '服务器中display_errors的状态为' . ini_get('display_errors');
    3. ?>

    :修改完php.ini文件,需要重启服务器。


    错误类型

    php大家最常见的错误显示截图,本书帮大家进行了总结:

    【掌握级别的错误类型】 我们将最常用的错误分为了三种:

    错误类型 说明
    E_ERROR 错误,文件直接中断
    E_WARNING 警告,问题比较严重。但是还会继续向下运行
    E_NOTICE 提示,有些小问题不会影响到程序。常发生在项目未定义
    E_PARSE 编译时语法解析错误。解析错误仅仅由分析器产生。
    E_ALL 所有的错误
    E_STRICT 启用PHP对代码的修改建议,以确保代码具有最佳的互操作性和向前兼容性。
    E_DEPRECATED 启用后将会对在未来版本中可能无法正常工作的代码给出警告。

    在上面的几种类型中:

    1. error 最严重,必须要解决。不然程序无法继续向下执行
    2. warning 也很重要。通也必须要解决。如果明确的,故意的可以不用处理。
    3. notice 你可以不用管。但是在有些公司,项目标准特别高。在高标准要求的项目中也必须要解决。因为,notice会影响到PHP的执行效率。通常发生在函数未定义等。
    4. parse 错误,是指语法错写错了,必须要解决
    5. 代表全部类型的所有错误

    【了解级别的错误类型】 再从这三种扩展出来了另外一些需要了解的错误项:

    错误类型 错误说明
    E_CORE_ERROR 在PHP初始化启动过程中发生的致命错误。该错误类似E_ERROR,但是是由PHP引擎核心产生的
    E_CORE_WARNING PHP初始化启动过程中发生的警告 (非致命错误) 。类似 E_WARNING,但是是由PHP引擎核心产生的。
    E_COMPILE_ERROR 致命编译时错误。类似E_ERROR,但是是由Zend脚本引擎产生的。
    E_COMPILE_WARNING 编译时警告(非致命错误)。类似E_WARNING,但是是由Zend脚本引擎产生的
    E_USER_ERROR 用户自定义错误
    E_USER_WARNING 用户自定义警告
    E_USER_NOTICE 用户自定义提示
    E_USER_DEPRECATED 用户产少的警告信息。类似E_DEPRECATED,但是是由用户自己在代码中使用PHP函数trigger_error()来产生的。
    E_RECOVERABLE_ERROR 可被捕捉的致命错误。它表示发生了一个可能非常危险的错误,但是还没有导致PHP引擎处于不稳定的状态。

    在学习过程中,上面的类型了解即可。因为基本不会遇到,遇到了大家查一下本书或者查一下手册就清楚了。

    error_reporting 报告错误类型

    error_reporting 是指错误报告。在php.ini中也有这样一个参数。这个参数。决定了PHP引擎记录、报告、显示哪些错误类型。

    • 在php.ini中error_reporting参数。如若error_reporting参数设置为0。整个PHP引擎发错误均不会显示、输出、记录。

    如果我们想显示所有错误可以写上:

    error_reporting = E_ALL

    想要显示所有错误但排除提示,可以将这个参数写为:

    error_reporting = E_ALL & ~ E_NOTICE

    显示所有错误,但排除提示、兼容性和未来兼容性。可写为:

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

    • 在有些情况下我们无权限操作php.ini文件,又想要控制error_reporting怎么办呢?

    在运行的xxxx.php文件中开始处,我们可以使用error_reporting()函数灰达到目标。

    演示代码如下:

    1. <?php
    2. //关闭了所有的错误显示
    3. error_reporting(0);
    4. //显示所有错误
    5. //error_reporting(E_ALL);
    6. //显示所有错误,但不显示提示
    7. //error_reporting(E_ALL & ~ E_NOTICE);
    8. ?>

    上面的代码你可以试试,故意写错代码看看。在当前文件中还会不会显示指定的错误。


    [扩展、了解知识点]: @ 符是我们之前学习过的单行不显示错误,请不用或者少用@符。

    我们拿读取一个不存在的文件,这样的php代码来演示实现过程:

    1. <?php
    2. //读取一个不存在的adsaf.txt文件,用@符抑制错误
    3. @$fp = fopen('adsaf.txt','r');
    4. ?>

    @符效率较低,它在php内核中的实现过程是:

    1. <?php
    2. //关闭错误
    3. error_reporting(0);
    4. //读取一个不存在的文件,显示错误
    5. //显示错误
    6. error_reporting(E_ALL & ~ E_NOTICE);
    7. ?>

    错误记录日志

    日志收集系统会在背后默默的帮你收集错误、警告、提示。类似Java中的Log4J等等,其中:PHP的错误,警告这些是必须要收信的。

    那么问题来了——不让用户看到,设置好错误报告级别好,如何将错误收集到日志系统中呢?

    这里有需要使用到php.ini的相关配置项。这两个配置项为:

    参数 配置项 说明
    log_errors on/off 是否开启日志记录
    log_errors_max_len 整型,默认1024 单行错误最大记录长度
    error_log syslog或者指定路径 错误日志记录在什么地方

    说明:

    1. 在表格中的log_errorslog_errors_max_len非常好理解。
    2. error_log 指定将错误存在什么路径上。配置项中的syslog可能有点不太好理解。syslog是指系统来记录。windows系统在电脑的日志收集器里面。linux默认在:/etc/syslog.conf

    [扩展] 了解知识点。若Linux系统启动或修改了日志收集。可能存储在第三方专用的日志收集服务器中。

    此外,PHP还为我们专门准备了一个自定义的错误日志函数:

    bool error_log ( string [,int错误消息类型 = 0 [, string $存储目标]] )

    这个函数可以把错误信息发送到web服务器的错误日志,或者到一个文件里。

    常用的错误消息类型:

    错误消息类型 说明
    0 发送至默认的error_log指定位置
    1 发送到指定的邮件位置
    3 发送至指定的文件位置

    示例:

    1. <?php
    2. //无法连接到数据库服务器,直接记录到php.ini 中的error_log指定位置
    3. error_log("无法连接到数据库服务器服务器");
    4. //可以发送邮件,但是php.ini必须配置过邮件系统
    5. error_log('可以用邮件报告错误,让运维人员半夜起床干活',1 ,'hanpang8983@foxmail.com');
    6. //记录在指定的位置
    7. error_log("我是一个错误哟", 3, "d:/test/my-errors.log");
    8. ?>

    注意:
    error_log 中发送邮件可能对初学者不熟,您可以不用掌握些块知识。


    量力而为,自定义异常函数

    这一块知识起点有些高。大多数人没有软件工程、自定义错误处理的经验,很难想象出使用的场景。若你想跳过此块的学习,完全可以,并且我们支持。

    此块知识点对于实际应用中应用场景不多。如果,有计划开始要自己写框架时、或者您做完了本书的第一个项目。

    您可以回头再来看11.4这一章的内容。

    用户自定义错误经常用到的两个函数:

    set_error_handler ( callable $回调的错误处理函数)
    设置一个用户定义的错误处理函数

    trigger_error ( string $error_msg)
    产生一个用户级别的 error/warning/notice 信息

    1. <?php
    2. //定义一个自定义的错误处理函数
    3. function customError($errno, $errstr, $errfile, $errline) {
    4. //输出错误消息
    5. echo "<b>Custom error:</b> [$errno] $errstr<br />";
    6. //输出错误文件和错误行
    7. echo "Error on line $errline in $errfile<br />";
    8. echo "Ending Script";
    9. //中止程序运行
    10. exit;
    11. }
    12. //使用set_error_handler 绑定用户自定义函数
    13. set_error_handler("customError");
    14. $test=2;
    15. //触发自定义错误
    16. if ($test > 1) {
    17. trigger_error("A custom error has been triggered");
    18. }
    19. ?>




  • 相关阅读:
    intel cpu 架构
    nginx-nagios-pnp4nagios-nrpe安装配置过程
    iostat 命令detail
    nagios环境
    编译安装PHP 5.3.13
    nagios支持PNP图形显示
    nagios配置安装
    在xp下禁用media sense
    linux awk常用命令【转载】
    sed命令解析[转载]
  • 原文地址:https://www.cnblogs.com/pangxiansheng/p/5751648.html
Copyright © 2020-2023  润新知