php 拡張機能によって返されるエラーを設定する方法: 1. 対応する PHP ファイルを開きます; 2. 拡張機能の「php_error_docref()」関数を通じてエラー プロンプトをスローします。
この記事の動作環境: Windows7 システム、PHP7.1 バージョン、DELL G3 パソコン
php 拡張子を返す方法error?
php ソース コード - 拡張機能でのエラーのスローと処理
まず、ソース コード レベルでのエラーの種類について説明します。次のタイプ
//zend_errors.h 文件 #define E_ERROR (1<<0L) #define E_WARNING (1<<1L) #define E_PARSE (1<<2L) #define E_NOTICE (1<<3L) #define E_CORE_ERROR (1<<4L) #define E_CORE_WARNING (1<<5L) #define E_COMPILE_ERROR (1<<6L) #define E_COMPILE_WARNING (1<<7L) #define E_USER_ERROR (1<<8L) #define E_USER_WARNING (1<<9L) #define E_USER_NOTICE (1<<10L) #define E_STRICT (1<<11L) #define E_RECOVERABLE_ERROR (1<<12L) #define E_DEPRECATED (1<<13L) #define E_USER_DEPRECATED (1<<14L)
このうち、E_CORE_ERROR、E_ERROR、E_RECOVERABLE_ERROR、E_PARSE、E_COMPILE_ERROR、E_USER_ERROR。このエラーは try catch 例外処理プロセスをトリガーし、現在のリクエストの実行を中断します。このエラーが発生した場合、現在実行されるオペコードは ZEND_HANDLE_EXCEPTION に設定されるため、プログラム実行のジャンプアウト、特定のジャンプアウトプロセスのリファレンス: PHP ソース コード - 例外スロー処理プロセス -02
エラーをスローする方法拡張機能を作成するときにプロンプトが表示されますか?
拡張エラー プロンプトは、
PHP_FUNCTION(academy_sample_fopen) { FILE *fp; char *filename, *mode; int filename_len, mode_len; if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "ss", &filename, &filename_len, &mode, &mode_len) == FAILURE) { RETURN_NULL(); } if (!filename_len || !mode_len) { php_error_docref(NULL TSRMLS_CC, E_WARNING,"Invalid filename or mode length"); RETURN_FALSE; } fp = fopen(filename, mode); if (!fp) { php_error_docref(NULL TSRMLS_CC, E_WARNING,"Unable to open %s using mode %s", filename, mode); RETURN_FALSE; } }
などの php_error_docref() 関数を通じてスローできます。これは、php_error_docref によるエラー プロンプトです。トリガーされると、次のエラーが発生します。プロンプト出力が表示されます
PHP コードを作成するときに同様のエラー プロンプト出力が表示されると思います。
PHP Fatal error: Unknown: EEEEEEEEEEEEEEEEEEE in Unknown on line 0 PHP Warning: Swoole\Php\Runner::run() expects exactly 4 parameters, 0 given in /var/www/swoole/http_test.php on line 22
このエラー プロンプト出力はどのようにして実現されますか?
php_error_docref
//main/php.h #define php_error_docref php_error_docref0 //main/main.c PHPAPI ZEND_COLD void php_error_docref0(const char *docref, int type, const char *format, ...) { va_list args; va_start(args, format); php_verror(docref, "", type, format, args); va_end(args); } //main/main.c PHPAPI ZEND_COLD void php_verror(const char *docref, const char *params, int type, const char *format, va_list args) { php_error(type, "%s", message); efree(message); } //main/php.h #define php_error zend_error //Zend/zend.c ZEND_API ZEND_COLD void zend_error(int type, const char *format, ...) /* {{{ */ { va_list va; va_start(va, format); zend_error_va_list(type, format, va); va_end(va); } static ZEND_COLD void zend_error_va_list(int type, const char *format, va_list args) { if (EG(exception)) { switch (type) { case E_CORE_ERROR: case E_ERROR: case E_RECOVERABLE_ERROR: case E_PARSE: case E_COMPILE_ERROR: case E_USER_ERROR: //严重错误,通过ZEND_HANDLE_EXCEPTION 中断程序 if (ex && ex->opline->opcode == ZEND_HANDLE_EXCEPTION && EG(opline_before_exception)) { opline = EG(opline_before_exception); } break; } } //... // zend_error_cb 很重要, 这个函数是在 sapi启动的时候,通过 php_module_startup() 赋值为 php_error_cb() 函数 zend_error_cb(type, error_filename, error_lineno, format, args); }
zend_error_cb のソース コードをフォローすることは非常に重要です。この関数は、sapi の起動時に php_module_startup() を通じて php_error_cb() 関数に割り当てられ、最終的に php_error_cb() はcalled_ sapi_module_struct.log_message()、つまり、php_error_docref() 関数を呼び出してエラーをスローすると、_sapi_module_struct.log_message が実際にコールバックされます (具体的な実行プロセスを参照してください: php ソース コード - sapi のカスタム エラー出力)。 fpm sapi など この関数をカスタマイズしてエラーメッセージを標準出力に出力することで、エラーメッセージが cli sapi に返されるようになります
推奨学習: "PHP Video Tutorial"
以上がPHP拡張エラーを返す方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。