PHP で致命的なエラーをキャッチする方法: register_shutdown_function() 関数を使用して致命的なエラーをキャッチできます。 register_shutdown_function() 関数は、PHP がプログラムの最後に特定の関数の動作をトリガーすることを示します。
register_shutdown_function() 関数を使用して致命的なエラーをキャプチャします。この関数は、PHP がプログラムの最後に特定の関数の動作をトリガーすることを示します。
(推奨チュートリアル: php グラフィック チュートリアル)
構文:
void register_shutdown_function(callable $callback[, mixed $parameter [, mixed $... ]])
スクリプトの実行が完了した後に実行されるコールバックを登録します。 exit() は後で呼び出されます。
パラメータ:
callback: 登録する中止コールバック
パラメータ: 渡すことができます追加のパラメータを入力して、中止関数にパラメータを渡します。
プログラムが終了する場合は、次の 4 つの状況があります。
実行中にエラーが発生しました。 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で致命的なエラーをキャッチする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。