温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么捕获php致命错误

发布时间:2020-08-07 09:33:27 来源:亿速云 阅读:109 作者:Leah 栏目:编程语言

这篇文章将为大家详细讲解有关怎么捕获php致命错误,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

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

利用register_shutdown_function()函数来捕获致命错误,该函数表示 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:17
Stack trace:
#0 {main}
  thrown
类型 : 1

关于怎么捕获php致命错误就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI