Heim >Backend-Entwicklung >PHP-Problem >So geben Sie einen PHP-Erweiterungsfehler zurück

So geben Sie einen PHP-Erweiterungsfehler zurück

藏色散人
藏色散人Original
2021-09-14 09:51:032217Durchsuche

So legen Sie den von der PHP-Erweiterung zurückgegebenen Fehler fest: 1. Öffnen Sie die entsprechende PHP-Datei. 2. Geben Sie über die Funktion „php_error_docref()“ eine Fehlermeldung aus.

So geben Sie einen PHP-Erweiterungsfehler zurück

Die Betriebsumgebung dieses Artikels: Windows 7-System, PHP-Version 7.1, DELL G3-Computer

Wie gebe ich einen PHP-Erweiterungsfehler zurück?

PHP-Quellcode – Fehler, die in der Erweiterung ausgelöst und verarbeitet werden

Lass uns zuerst darüber reden. Es gibt wahrscheinlich die folgenden Arten von Fehlern auf Quellcodeebene

//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)

Darunter E_CORE_ERROR, E_ERROR, E_RECOVERABLE_ERROR, E_PARSE, E_COMPILE_ERROR, E_USER_ERROR. Dieser Fehler löst den Try-Catch-Ausnahmebehandlungsprozess aus, der unterbrochen wird Wenn ein Fehler auftritt, wird der aktuell auszuführende Opcode auf ZEND_HANDLE_EXCEPTION gesetzt, wodurch die Programmausführung unterbrochen wird. Informationen zum spezifischen Sprungvorgang finden Sie unter: PHP-Quellcode – Ausnahme Verarbeitungsprozess auslösen - 02

Wie lösen wir beim Schreiben einer Erweiterung eine Fehlermeldung aus?

Erweiterungen können Fehlermeldungen über die Funktion php_error_docref() auslösen, z. B.

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;
    }
}

Über php_error_docref ist dies die Fehlermeldung If Ausgelöst wird die folgende Fehleraufforderungsausgabe angezeigt

Ich glaube, dass dies auch beim Schreiben von PHP-Code passieren wird. Haben Sie jemals eine so ähnliche Fehlermeldungsausgabe gesehen

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

Wie wird diese Fehlermeldungsausgabe erreicht?

Verfolgen Sie den Quellcode von 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. Diese Funktion wird der Funktion php_error_cb() beim Start von sapi zugewiesen, und php_error_cb() ruft schließlich _sapi_module_struct.log_message() auf Wenn Sie die Funktion php_error_docref() aufrufen, um einen Fehler auszulösen, wird _sapi_module_struct.log_message tatsächlich zurückgerufen (Informationen zum spezifischen Ausführungsprozess finden Sie unter: Benutzerdefinierte Fehlerausgabe im PHP-Quellcode-sapi. Beispielsweise gibt fpm sapi Folgendes zurück). Fehlermeldung an, cli sapi gibt Fehlerinformationen an die Standardausgabe aus, indem diese Funktion angepasst wird

Empfohlenes Lernen: „PHP-Video-Tutorial

Das obige ist der detaillierte Inhalt vonSo geben Sie einen PHP-Erweiterungsfehler zurück. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn