略微加速

略速 - 互联网笔记

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

2017-06-15 leiting (3162阅读)

标签 PHP

set_error_handler

(PHP 4 >= 4.0.1, PHP 5, PHP 7)

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

说明

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_ERRORE_COMPILE_WARNING,和在 调用 set_error_handler() 函数所在文件中产生的大多数 E_STRICT

如果错误发生在脚本执行之前(比如文件上传时),将不会 调用自定义的错误处理程序因为它尚未在那时注册。

参数


  • error_handler

  • 以下格式的回调(callback): 可以传入 NULL 重置处理程序到默认状态。 除了可以传入函数名,还可以传入引用对象和对象方法名的数组。


    bool handler ( int $errno , string $errstr [, string $errfile [, int $errline [, array $errcontext ]]] )

    如果函数返回 FALSE,标准错误处理处理程序将会继续调用。

    • errno

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

    • errstr

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

    • errfile

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

    • errline

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

    • errcontext

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

      Warning

      PHP 7.2.0 后此参数被弃用了。 极其不建议依赖它。

  • error_types

  • 就像error_reporting 的 ini 设置能够控制错误的显示一样, 此参数能够用于屏蔽 error_handler 的触发。 如果没有该掩码, 无论 error_reporting 是如何设置的, error_handler 都会在每个错误发生时被调用。

返回值

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

更新日志


版本说明
7.2.0errcontext 被废弃。 使用此参数时会导致 E_DEPRECATED 提醒。
5.5.0error_handler 可接收 NULL
5.2.0错误处理器必须返回 FALSE 来显示 $php_errormsg


http://php.net/manual/zh/function.set-error-handler.php


北京半月雨文化科技有限公司.版权所有 京ICP备12026184号-3