PHP set_error_handler() 函数用法及示例

PHP Error & Loggings 参考手册

set_error_handler()函数设置用户自定义的错误处理函数

语法

mixed set_error_handler ( callback $error_handler [, int $error_types] );

定义和用法

设置用户的函数 (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。
如果错误发生在脚本执行之前(比如文件上传时),将不会 调用自定义的错误处理程序因为它尚未在那时注册。

参数

序号参数及说明
1

error_handler(必需)

它指定要在错误时运行的函数。下面给出error_handler的语法。

2

error_types(可选)

它指定将在哪个错误报告级别上显示用户定义的错误。默认值为“ E_ALL”。有关可能的错误报告级别,请参见“ PHP错误和日志记录常数:”。

错误处理程序函数语法

error_function(error_level,error_message, error_file,error_line,error_context);

这是paramenter的描述-

  • errno  -  第一个参数 errno,包含了错误的级别,是一个 integer。

  • errstr  -  第二个参数 errstr,包含了错误的信息,是一个 string。

  • errfile - 第三个参数是可选的,errfile, 包含了发生错误的文件名,是一个 string。

  • errline - 第四个参数是一个可选项, errline, 包含了错误发生的行号,是一个 integer。

  • errcontext - 第五个可选参数, errcontext, 是一个指向错误发生时活动符号表的 array。 也就是说,errcontext 会包含错误触发处作用域内所有变量的数组。 用户的错误处理程序不应该修改错误上下文(context)。

返回值

 如果之前有定义过错误处理程序,则返回该程序名称的 string;如果是内置的错误处理程序,则返回 NULL。 如果你指定了一个无效的回调函数,同样会返回 NULL。 如果之前的错误处理程序是一个类的方法,此函数会返回一个带类和方法名的索引数组(indexed array)。

在线示例

以下是此set_error_handler函数的用法:

<?php
   function customError($errno, $errstr, $errfile, $errline) {
      echo "Custom error: [$errno] $errstr\n";
      echo "Error on line $errline in $errfile\n";
      echo "Ending Script";
      
      die();
   }
   
   //设置错误处理程序
   set_error_handler("customError");
   $test = 0;
   
   //触发错误
   if ($test >  -1) {
      trigger_error("已触发自定义错误");
   }
?>
测试看看‹/›

输出结果:

Custom error: [1024] A custom error has been triggered Error on line 16 
in /home/cg/root/1531703/main.php 
Ending Script