Bagaimana untuk mengembalikan ralat sambungan php

藏色散人
Lepaskan: 2023-03-12 14:22:02
asal
2173 orang telah melayarinya

Cara menetapkan ralat yang dikembalikan oleh sambungan php: 1. Buka fail PHP yang sepadan 2. Lemparkan gesaan ralat melalui fungsi "php_error_docref()" dalam sambungan.

Bagaimana untuk mengembalikan ralat sambungan php

Persekitaran pengendalian artikel ini: sistem Windows 7, PHP versi 7.1, komputer DELL G3

Cara mengembalikan php ralat sambungan?

kod sumber php - ralat yang dibuang dan dikendalikan dalam sambungan

Mari kita bincangkan tentang jenis ralat pada tahap kod sumber mungkin jenis berikut

//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)
Salin selepas log masuk

Antaranya, E_CORE_ERROR, E_ERROR, E_RECOVERABLE_ERROR, E_PARSE, E_COMPILE_ERROR, E_USER_ERROR Ralat ini akan mencetuskan proses pengendalian pengecualian try catch, yang akan mengganggu permintaan exe semasa ralat ini berlaku, opcode yang akan dilaksanakan pada masa ini akan ditetapkan kepada ZEND_HANDLE_EXCEPTION , dengan itu melompat keluar daripada pelaksanaan program, sila rujuk kepada: kod sumber PHP - proses pemprosesan lontaran pengecualian - 02

. Bagaimanakah kita membuang gesaan ralat semasa menulis sambungan?

Sambungan boleh membuang gesaan ralat melalui fungsi php_error_docref(), seperti

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;
    }
}
Salin selepas log masuk

Ini ialah gesaan ralat melalui php_error_docref Jika dicetuskan, output gesaan ralat berikut akan muncul

Saya percaya anda telah melihat output gesaan ralat yang serupa semasa menulis kod 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
Salin selepas log masuk

Bagaimanakah output gesaan ralat ini dicapai ?

Ikuti kod sumber 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);
}
Salin selepas log masuk

zend_error_cb adalah sangat penting Fungsi ini diberikan kepada fungsi php_error_cb() melalui php_module_startup() apabila sapi bermula, dan php_error akan. akhirnya Panggil _sapi_module_struct.log_message(), iaitu, apabila anda memanggil fungsi php_error_docref() untuk membuang ralat, _sapi_module_struct.log_message sebenarnya akan dipanggil semula (rujuk proses pelaksanaan khusus: output ralat tersuai kod sumber php dalam sapi) , contohnya fpm sapi akan mengembalikan mesej ralat kepada cli sapi dengan menyesuaikan fungsi ini untuk mengeluarkan mesej ralat kepada output standard

Pembelajaran yang disyorkan: "Tutorial Video PHP"

Atas ialah kandungan terperinci Bagaimana untuk mengembalikan ralat sambungan php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
php
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan