PHP set_error_handler() 函数用法及示例
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