zoukankan      html  css  js  c++  java
  • PHP 错误与异常 笔记与总结(8)自定义错误处理函数 set_error_handler()

    通过 Set_error_handler() 函数设置用户自定义的错误处理函数。

    步骤:

    ① 创建错误处理函数

    ② 设置不同级别调用函数

    Set_error_handler() 函数制定接管错误处理—— 如果使用了该函数,程序会绕过标准的 PHP 错误处理。

    摘自:php.net

    mixed set_error_handler ( callable $error_handler [, int $error_types = E_ALL | E_STRICT ] )
    设置一个用户的函数(error_handler)来处理脚本中出现的错误。
    
    本函数可以用你自己定义的方式来处理运行中的错误, 例如,在应用程序中严重错误发生时,或者在特定条件下触发了一个错误(使用 trigger_error()),你需要对数据/文件做清理回收。
    
    重要的是要记住 error_types 里指定的错误类型都会绕过 PHP 标准错误处理程序, 除非回调函数返回了 FALSE。 error_reporting() 设置将不会起到作用而你的错误处理函数继续会被调用 —— 不过你仍然可以获取 error_reporting 的当前值,并做适当处理。 需要特别注意的是带 @ error-control operator 前缀的语句发生错误时,这个值会是 0。
    
    同时注意,在需要时你有责任使用 die()。 如果错误处理程序返回了,脚本将会继续执行发生错误的后一行。
    
    以下级别的错误不能由用户定义的函数来处理: E_ERROR、 E_PARSE、 E_CORE_ERROR、 E_CORE_WARNING、 E_COMPILE_ERROR、 E_COMPILE_WARNING,和在 调用 set_error_handler() 函数所在文件中产生的大多数 E_STRICT。
    error_handler
    用户的函数需要接受两个参数:错误码和描述错误的 string。 另外有可能提供三个可选参数:发生错误的文件名、发生错误的行号 以及发生错误的上下文(一个指向错误发生时活动符号表的 array)。 该函数可以表示为:
    
    handler ( int $errno , string $errstr [, string $errfile [, int $errline [, array $errcontext ]]] )
    errno
    第一个参数 errno,包含了错误的级别,是一个 integer。
    errstr
    第二个参数 errstr,包含了错误的信息,是一个 string。
    errfile
    第三个参数是可选的,errfile, 包含了发生错误的文件名,是一个 string。
    errline
    第四个参数是一个可选项, errline, 包含了错误发生的行号,是一个 integer。
    errcontext
    第五个可选参数, errcontext, 是一个指向错误发生时活动符号表的 array。 也就是说,errcontext 会包含错误触发处作用域内所有变量的数组。 用户的错误处理程序不应该修改错误上下文(context)。
    如果函数返回 FALSE,标准错误处理处理程序将会继续调用。
    
    error_types
    就像error_reporting 的 ini 设置能够控制错误的显示一样, 此参数能够用于屏蔽 error_handler 的触发。 如果没有该掩码, 无论 error_reporting 是如何设置的, error_handler 都会在每个错误发生时被调用。
    
    返回值
    
    如果之前有定义过错误处理程序,则返回该程序名称的 string;如果是内置的错误处理程序,则返回 NULL。 如果你指定了一个无效的回调函数,同样会返回 NULL。 如果之前的错误处理程序是一个类的方法,此函数会返回一个带类和方法名的索引数组(indexed array)。

    【例1】

    a.使用 PHP 内置错误处理函数(使用自定义错误处理函数被注释掉了)

    <?php
    header('content-type:text/html;charset=utf-8');
    //显示所有错误
    error_reporting(-1);
    
    //自定义错误处理程序
    //参数1:$errno 错误级别
    //参数2:$errmsg 错误信息
    //参数3:$file 错误文件
    //参数4:$line 错误行号
    function customerError($errno, $errmsg, $file, $line){
        echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
        echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
        echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
        die;
    }
    
    //使用自定义错误处理程序接管内置的 PHP 错误处理程序
    //set_error_handler('customerError');
    
    //测试
    echo $test;

    输出:

    ( ! ) Notice: Undefined variable: test in D:practisephpErrorerror1.php on line 22

    b.使用自定义错误处理函数:

    <?php
    header('content-type:text/html;charset=utf-8');
    //显示所有错误
    error_reporting(-1);
    
    //自定义错误处理程序
    //参数1:$errno 错误级别
    //参数2:$errmsg 错误信息
    //参数3:$file 错误文件
    //参数4:$line 错误行号
    function customerError($errno, $errmsg, $file, $line){
        echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
        echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
        echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
        die;
    }
    
    //使用自定义错误处理程序接管内置的 PHP 错误处理程序
    set_error_handler('customerError');
    
    //测试
    echo $test;

    输出:

    错误代码: [8] Undefined variable: test
    错误行号: D:practisephpErrorerror1.php文件中的第22行
    PHP 版本: 5.3.10(WINNT)

    c. 测试 警告 与 致命错误:

    <?php
    header('content-type:text/html;charset=utf-8');
    //显示所有错误
    error_reporting(-1);
    
    //自定义错误处理程序
    //参数1:$errno 错误级别
    //参数2:$errmsg 错误信息
    //参数3:$file 错误文件
    //参数4:$line 错误行号
    function customerError($errno, $errmsg, $file, $line){
        echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
        echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
        echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
        //die;
    }
    
    //使用自定义错误处理程序接管内置的 PHP 错误处理程序
    set_error_handler('customerError');
    
    //测试
    //Notice
    echo $test;
    echo '<hr/>';
    
    //Warning
    settype($var, 'dee');
    echo '<hr/>';
    
    //Fatal Error:依然使用内置的 PHP 错误处理函数
    echo dee();

    输出:

    错误代码: [8] Undefined variable: test
    错误行号: D:practisephpErrorerror1.php文件中的第22行
    PHP 版本: 5.3.10(WINNT)
    
    ---------------------------------------------------------------------
    错误代码
    : [2] settype() [function.settype]: Invalid type 错误行号: D:practisephpErrorerror1.php文件中的第24行 PHP 版本: 5.3.10(WINNT)
    ---------------------------------------------------------------------
    (
    ! ) Fatal error: Call to undefined function dee() in D:practisephpErrorerror1.php on line 26

    d. 测试手动抛出错误

    <?php
    header('content-type:text/html;charset=utf-8');
    //显示所有错误
    error_reporting(-1);
    
    //自定义错误处理程序
    //参数1:$errno 错误级别
    //参数2:$errmsg 错误信息
    //参数3:$file 错误文件
    //参数4:$line 错误行号
    function customerError($errno, $errmsg, $file, $line){
        echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
        echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
        echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
        //die;
    }
    
    //使用自定义错误处理程序接管内置的 PHP 错误处理程序
    set_error_handler('customerError');
    
    //测试
    //Notice
    echo $test;
    echo '<hr/>';
    
    //Warning
    settype($var, 'dee');
    echo '<hr/>';
    
    //Fatal Error:依然使用内置的 PHP 错误处理函数
    //echo dee();
    
    //手动抛出错误
    trigger_error('a test of error',  E_USER_ERROR);

    输出:

    错误代码: [8] Undefined variable: test
    错误行号: D:practisephpErrorerror1.php文件中的第23行
    PHP 版本: 5.3.10(WINNT)

    ---------------------------------------------------------
    错误代码
    : [2] settype() [function.settype]: Invalid type 错误行号: D:practisephpErrorerror1.php文件中的第27行 PHP 版本: 5.3.10(WINNT)

    ---------------------------------------------------------
    错误代码
    : [256] a test of error 错误行号: D:practisephpErrorerror1.php文件中的第34行 PHP 版本: 5.3.10(WINNT)

    注:如果不使用用户自定错误,而使用 PHP 内置的错误处理程序,当遇到 E_USER_ERROR 级别的错误时,会报致命错误 Fatal Error,并且程序终止向下执行。

    e.在同一脚本中如果不想使用自定义错误处理函数时,可以使用 restore_error_handler() 函数取消自定义错误处理函数的接管。

    <?php
    header('content-type:text/html;charset=utf-8');
    //显示所有错误
    error_reporting(-1);
    
    //自定义错误处理程序
    //参数1:$errno 错误级别
    //参数2:$errmsg 错误信息
    //参数3:$file 错误文件
    //参数4:$line 错误行号
    function customerError($errno, $errmsg, $file, $line){
        echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
        echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
        echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
        //die;
    }
    
    //使用自定义错误处理程序接管内置的 PHP 错误处理程序
    set_error_handler('customerError');
    
    //测试
    //Notice
    echo $test;
    echo '<hr/>';
    
    //Warning
    settype($var, 'dee');
    echo '<hr/>';
    
    //Fatal Error:依然使用内置的 PHP 错误处理函数
    //echo dee();
    
    //手动抛出错误,并且程序终止执行
    trigger_error('a test of error', E_USER_ERROR);
    
    //取消使用自定义错误处理函数
    restore_error_handler();
    echo $dee;

    输出:

    错误代码: [8] Undefined variable: test
    错误行号: D:practisephpErrorerror1.php文件中的第23行
    PHP 版本: 5.3.10(WINNT)

    ----------------------------------------------------------
    错误代码
    : [2] settype() [function.settype]: Invalid type 错误行号: D:practisephpErrorerror1.php文件中的第27行 PHP 版本: 5.3.10(WINNT)

    ----------------------------------------------------------
    错误代码
    : [256] a test of error 错误行号: D:practisephpErrorerror1.php文件中的第34行 PHP 版本: 5.3.10(WINNT) ( ! ) Notice: Undefined variable: dee in D:practisephpErrorerror1.php on line 38

    f. 继续使用自定义处理函数接管错误处理,并设置set_error_handler() 函数的第二个参数:设置哪些错误交给自定义错误函数处理:

    <?php
    header('content-type:text/html;charset=utf-8');
    //显示所有错误
    error_reporting(-1);
    
    //自定义错误处理程序
    //参数1:$errno 错误级别
    //参数2:$errmsg 错误信息
    //参数3:$file 错误文件
    //参数4:$line 错误行号
    function customerError($errno, $errmsg, $file, $line){
        echo "<b>错误代码: </b>[{$errno}] {$errmsg}<br />".PHP_EOL;
        echo "<b>错误行号: </b>{$file}文件中的第{$line}行<br />".PHP_EOL;
        echo "<b>PHP 版本: </b>".PHP_VERSION."(".PHP_OS.")<br />".PHP_EOL;
        //die;
    }
    
    //使用自定义错误处理程序接管内置的 PHP 错误处理程序
    set_error_handler('customerError');
    
    //测试
    //Notice
    echo $test;
    echo '<hr/>';
    
    //Warning
    settype($var, 'dee');
    echo '<hr/>';
    
    //Fatal Error:依然使用内置的 PHP 错误处理函数
    //echo dee();
    
    //手动抛出错误,并且程序终止执行
    trigger_error('a test of error', E_USER_ERROR);
    
    //取消使用自定义错误处理函数
    restore_error_handler();
    echo $dee;
    echo '<hr>';
    
    //继续使用自定义错误处理函数,并且设置除了 Notice 级别的错误外的错误,交给自定义错误处理函数处理
    set_error_handler('customerError', E_ALL&~E_NOTICE);
    echo $dee;
    
    echo 'continue';

    输出:

    错误代码: [8] Undefined variable: test
    错误行号: D:practisephpErrorerror1.php文件中的第23行
    PHP 版本: 5.3.10(WINNT)

    ---------------------------------------------------------------
    错误代码
    : [2] settype() [function.settype]: Invalid type 错误行号: D:practisephpErrorerror1.php文件中的第27行 PHP 版本: 5.3.10(WINNT)

    --------------------------------------------------------------
    错误代码
    : [256] a test of error 错误行号: D:practisephpErrorerror1.php文件中的第34行 PHP 版本: 5.3.10(WINNT)
    (
    ! ) Notice: Undefined variable: dee in D:practisephpErrorerror1.php on line 38
    --------------------------------------------------------------
    (
    ! ) Notice: Undefined variable: dee in D:practisephpErrorerror1.php on line 43

    注:

    换行符
    
    unix系列用 
    
    
    windows系列用 
    
    
    mac用 
    
    
    PHP中可以用PHP_EOL来替代,以提高代码的源代码级可移植性

    参考:http://www.cnblogs.com/codefor/archive/2011/06/18/2084300.html
  • 相关阅读:
    [ html canvas 案例 -- 绘制文本图片 ] canvas案例 -- 绘制文本图片演示
    [ javascript 创建随机颜色 ] 多种方式来创建随机颜色
    [ html canvas shadowOffsetX shadowOffsetY shadowBlur shadowColor ] canvas绘图属性 shadowOffsetX shadowOffsetY shadowBlur shadowColor 属性演示
    [ html canvas font textAlign textBaseline measureText().width ] canvas绘图属性 font textAlign textBaseline measureText().width 属性演示
    [ html canvas ] canvas绘制太阳系实例代码
    [ html canvas quadraticCurveTo ] canvas绘图quadraticCurveTo()属性研究实例演示之二
    [ html canvas arcTo ] canvas绘图 arcTo()属性研究实例演示之二
    [ html createLinearGradient createRadialGradient 绘制背景渐变方式 ] canvas绘制渐变 createLinearGradient createRadialGradient 绘制背景渐变方式 属性实例
    hadoop常见问题汇总
    hive数据导入
  • 原文地址:https://www.cnblogs.com/dee0912/p/4532010.html
Copyright © 2011-2022 走看看