php怎么捕获致命错误
2022-12-02 09:01:16
195
{{single.collect_count}}

php捕获致命错误的方法:可以利用register_shutdown_function()函数来捕获致命错误。register_shutdown_function()函数表示PHP在程序结束时触发某个函数行为。

php入门到就业线上直播课:进入学习
Apipost = Postman + Swagger + Mock + Jmeter 超好用的API调试工具:点击使用

利用register_shutdown_function()函数来捕获致命错误,该函数表示 PHP 在程序结束时触发某个函数行为。

(推荐教程:php图文教程

语法:

void register_shutdown_function(callable $callback[, mixed $parameter [, mixed $... ]])
登录后复制

注册一个 callback ,它会在脚本执行完成或者 exit() 后被调用。

参数:

  • callback:待注册的中止回调

  • parameter:可以通过传入额外的参数来将参数传给中止函数

程序结束有四种情况:

  • php代码执行过程中发生错误

  • php代码顺利执行成功

  • php代码运行超时

  • 页面被用户强制停止

(视频教程推荐:编程入门

举例:

我们自定义一个行为:

<?php/** * Created by PhpStorm. * User: Xavier * Date: 2018/6/3 * Time: 12:16 */class RegisterShutDownFunction{/** * @author Xavier * @desc php 程序运行结束时候需要运行的函数 */public static function register(){if ($error = error_get_last()) {// $filename 必须是一个绝对路径if (!defined('REGISTER_SHUTDOWN_FUNCTION_LOG_FILENAME')) {$filename = dirname(__FILE__) . DIRECTORY_SEPARATOR . 'register_shutdown_function.log';} else {$filename = REGISTER_SHUTDOWN_FUNCTION_LOG_FILENAME;}$message = '时间 : ' . date('Y-m-d H:i:s') . PHP_EOL;$message .= '文件 : ' . $error['file'] . PHP_EOL;$message .= '行数 : ' . $error['line'] . PHP_EOL;$message .= '错误 : ' . $error['message'] . PHP_EOL;$message .= '类型 : ' . $error['type'] . PHP_EOL . PHP_EOL;file_put_contents($filename, $message, FILE_APPEND);}}}
登录后复制

应用:

<?php/** * Created by PhpStorm. * User: Xavier * Date: 2018/6/3 * Time: 12:27 */ // 定义一个常量来记录程序停止后,出现错误的 LOG 日志文件define('REGISTER_SHUTDOWN_FUNCTION_LOG_FILENAME', dirname(__FILE__) . DIRECTORY_SEPARATOR . '11.log');// 包含异常处理的类文件include 'lib/RegisterShutDownFunction.php';$registerShutDownFunction = new RegisterShutDownFunction();// register_shutdown_function 函数必须在所有的程序执行之间注册register_shutdown_function(array($registerShutDownFunction, 'register'));// 注册成功之后调用一个不存在的方法 aa();aa();
登录后复制

错误日志:

时间 : 2018-06-03 04:56:02文件 : /Users/x/www/php/exception/2.php行数 : 17错误 : Uncaught Error: Call to undefined function aa() in /Users/x/www/php/exception/2.php:17Stack trace:#0 {main}thrown类型 : 1
登录后复制

以上就是php怎么捕获致命错误的详细内容,更多请关注php中文网其它相关文章!

回帖
全部回帖({{commentCount}})
{{item.user.nickname}} {{item.user.group_title}} {{item.friend_time}}
{{item.content}}
{{item.comment_content_show ? '取消' : '回复'}} 删除
回帖
{{reply.user.nickname}} {{reply.user.group_title}} {{reply.friend_time}}
{{reply.content}}
{{reply.comment_content_show ? '取消' : '回复'}} 删除
回帖
收起
没有更多啦~
{{commentLoading ? '加载中...' : '查看更多评论'}}