>백엔드 개발 >PHP 문제 >PHP 확장 오류를 반환하는 방법

PHP 확장 오류를 반환하는 방법

藏色散人
藏色散人원래의
2021-09-14 09:51:032230검색

php 확장에서 반환되는 오류를 설정하는 방법: 1. 해당 PHP 파일을 엽니다. 2. 확장에서 "php_error_docref()" 함수를 통해 오류 프롬프트를 표시합니다.

PHP 확장 오류를 반환하는 방법

이 문서의 운영 환경: Windows 7 시스템, PHP 버전 7.1, DELL G3 컴퓨터

PHP 확장 오류를 반환하는 방법

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 예외 처리 프로세스를 트리거하여 중단됩니다. 이 경우 오류가 발생하면 현재 실행 중인 opcode가 ZEND_HANDLE_EXCEPTION으로 설정되어 프로그램 실행에서 빠져나옵니다. 자세한 점프 아웃 프로세스는 PHP 소스 코드 - 예외를 참조하세요. throw 처리 프로세스 - 02

확장 프로그램을 작성할 때 오류 메시지를 어떻게 표시하나요?

확장 프로그램은 php_error_docref() 함수를 통해 오류 메시지를 표시할 수 있습니다. 예를 들어

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 코드를 작성할 때도 이런 일이 발생할 것이라고 생각합니다. 이렇게 비슷한 오류 메시지 출력을 본 적이 있습니까?

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()는 결국 _sapi_module_struct.log_message()를 호출하게 됩니다. 오류를 발생시키기 위해 php_error_docref() 함수를 호출하면 _sapi_module_struct.log_message가 실제로 콜백됩니다(특정 실행 프로세스에 대해서는 PHP 소스 코드-sapi의 사용자 정의 오류 출력을 참조하십시오). 예를 들어, fpm sapi는 다음을 반환합니다. 오류 메시지, cli sapi는 이 기능을 사용자 정의하여 오류 정보를 표준 출력으로 출력합니다

권장 학습: "PHP 비디오 튜토리얼"

위 내용은 PHP 확장 오류를 반환하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.