Rumah pembangunan bahagian belakang tutorial php Petua pengendalian ralat PHP 7: Cara menggunakan fungsi set_error_handler untuk log ralat ke fail log

Petua pengendalian ralat PHP 7: Cara menggunakan fungsi set_error_handler untuk log ralat ke fail log

Aug 01, 2023 pm 08:43 PM
php Ralat pengendalian set_error_handler

Kemahiran pengendalian ralat PHP 7: Cara menggunakan fungsi set_error_handler untuk merekod ralat pada fail log

Semasa proses pembangunan, adalah sangat penting untuk menangkap dan merekod ralat dengan tepat. PHP menyediakan pelbagai mekanisme pengendalian ralat, salah satunya adalah menggunakan fungsi set_error_handler untuk menyesuaikan pengendali ralat. Artikel ini akan memperkenalkan cara menggunakan fungsi set_error_handler untuk merekodkan ralat PHP pada fail log supaya kami boleh menjejak dan menyelesaikan masalah dengan lebih baik.

1. Pengenalan kepada fungsi set_error_handler
Fungsi set_error_handler digunakan untuk menetapkan fungsi pengendalian ralat yang ditentukan pengguna. Fungsi ini dipanggil apabila PHP menghadapi ralat, memberikannya maklumat ralat sebagai parameter. Kita boleh menyesuaikan proses pengendalian ralat melalui fungsi ini.

Berikut ialah sintaks asas fungsi set_error_handler:

bool set_error_handler ( callable $error_handler [, int $error_types = E_ALL | E_STRICT ] )

Antaranya, parameter $errorable handler ialah parameter $errorable handler Selain itu, parameter $error_types ialah parameter pilihan yang digunakan untuk menentukan jenis ralat Jika tidak dinyatakan, nilai lalai E_ALL | E_STRICT akan digunakan, iaitu, semua dan ralat ketat akan diproses.

2. Langkah-langkah merekod ralat ke fail log

  1. Buat fail log
    Pertama, kita perlu mencipta fail log untuk menyimpan maklumat ralat. Anda boleh menamakan fail log "error.log" atau mana-mana nama lain yang anda suka.
  2. Buat fungsi pengendalian ralat tersuai
    Seterusnya, kita perlu mencipta fungsi pengendalian ralat tersuai untuk menulis maklumat ralat pada fail log. Berikut ialah contoh fungsi pengendalian ralat:

fungsi custom_error_handler($error_number, $error_message, $error_file, $error_line) {

// 将错误信息写入日志文件
$log_message = "[" . date('Y-m-d H:i:s') . "] " . "Error: " . $error_message . " in " . $error_file . " on line " . $error_line . "
Salin selepas log masuk
Salin selepas log masuk

";

error_log($log_message, 3, 'error.log');
Salin selepas log masuk
Salin selepas log masuk

}

Dalam contoh fail dan nombor baris ini, kita akan digabungkan menjadi mesej log dan fungsi error_log digunakan untuk menulis mesej ke fail log

  1. Tetapkan fungsi pengendalian ralat tersuai menggunakan fungsi set_error_handler
    Akhir sekali, kami akan menggunakan fungsi set_error_handler untuk menetapkan fungsi pengendalian ralat tersuai. . Tetapkan sebagai pengendali ralat global. Fungsi ini perlu digunakan di mana-mana ralat perlu ditangkap sepanjang aplikasi Hanya panggil fungsi set_error_handler pada entri program utama, seperti yang ditunjukkan di bawah:
set_error_handler('custom_error_handler' );

Sekarang, apabila PHP menghadapi ralat, ia akan memanggil fungsi custom_error_handler yang kami tentukan dan menghantar maklumat ralat kepadanya. Kemudian, maklumat ralat akan ditulis ke fail log

3. Kod sampel lengkap yang menunjukkan cara menggunakan fungsi set_error_handler untuk log ralat ke fail log:

// Cipta fungsi pengendalian ralat tersuai
function custom_error_handler($error_number, $error_message, $error_file, $error_line ) {

// 将错误信息写入日志文件
$log_message = "[" . date('Y-m-d H:i:s') . "] " . "Error: " . $error_message . " in " . $error_file . " on line " . $error_line . "
Salin selepas log masuk
Salin selepas log masuk

";

error_log($log_message, 3, 'error.log');
Salin selepas log masuk
Salin selepas log masuk

}

//Tetapkan fungsi pengendalian ralat tersuai

set_error_handler('custom_error_handler');

// Sengaja mencetuskan ralat

echo $undefined ralat trigger_error("Ini adalah ralat ujian", E_USER_NOTICE);
?>

Dalam kod di atas, kami mula-mula mencipta fungsi pengendalian ralat tersuai custom_error_handler. Kemudian, gunakan fungsi set_error_handler untuk menetapkan fungsi sebagai pengendali ralat global. Seterusnya, proses pengendalian ralat ditunjukkan dengan menggemakan pembolehubah yang tidak ditentukan dan mencetuskan ralat tersuai.

4. Kesimpulan

Dengan menggunakan fungsi set_error_handler, kami boleh merekodkan maklumat ralat PHP ke dalam fail log untuk memudahkan pengesanan ralat dan penyelesaian masalah kami yang seterusnya. Kaedah ini sangat berguna untuk pasukan pembangunan dan boleh meningkatkan kecekapan pembangunan dan kualiti kod.

Ingat bahawa pengendalian ralat adalah bahagian yang sangat penting Mekanisme pengendalian ralat yang baik boleh meningkatkan kestabilan dan kebolehpercayaan aplikasi. Saya harap artikel ini dapat membantu semua orang lebih memahami dan menggunakan kemahiran pengendalian ralat PHP 7.

Atas ialah kandungan terperinci Petua pengendalian ralat PHP 7: Cara menggunakan fungsi set_error_handler untuk log ralat ke fail log. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

7 Fungsi PHP Saya Menyesal Saya Tidak Tahu Sebelum ini 7 Fungsi PHP Saya Menyesal Saya Tidak Tahu Sebelum ini Nov 13, 2024 am 09:42 AM

Jika anda seorang pembangun PHP yang berpengalaman, anda mungkin merasakan bahawa anda telah berada di sana dan telah melakukannya. Anda telah membangunkan sejumlah besar aplikasi, menyahpenyahpepijat berjuta-juta baris kod dan mengubah suai sekumpulan skrip untuk mencapai op

Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Dec 20, 2024 am 11:31 AM

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Apr 05, 2025 am 12:04 AM

JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Bagaimana anda menghuraikan dan memproses HTML/XML dalam PHP? Bagaimana anda menghuraikan dan memproses HTML/XML dalam PHP? Feb 07, 2025 am 11:57 AM

Tutorial ini menunjukkan cara memproses dokumen XML dengan cekap menggunakan PHP. XML (bahasa markup extensible) adalah bahasa markup berasaskan teks yang serba boleh yang direka untuk pembacaan manusia dan parsing mesin. Ia biasanya digunakan untuk penyimpanan data

Program PHP untuk mengira vokal dalam rentetan Program PHP untuk mengira vokal dalam rentetan Feb 07, 2025 pm 12:12 PM

Rentetan adalah urutan aksara, termasuk huruf, nombor, dan simbol. Tutorial ini akan mempelajari cara mengira bilangan vokal dalam rentetan yang diberikan dalam PHP menggunakan kaedah yang berbeza. Vokal dalam bahasa Inggeris adalah a, e, i, o, u, dan mereka boleh menjadi huruf besar atau huruf kecil. Apa itu vokal? Vokal adalah watak abjad yang mewakili sebutan tertentu. Terdapat lima vokal dalam bahasa Inggeris, termasuk huruf besar dan huruf kecil: a, e, i, o, u Contoh 1 Input: String = "TutorialSpoint" Output: 6 menjelaskan Vokal dalam rentetan "TutorialSpoint" adalah u, o, i, a, o, i. Terdapat 6 yuan sebanyak 6

Terangkan pengikatan statik lewat dalam php (statik: :). Terangkan pengikatan statik lewat dalam php (statik: :). Apr 03, 2025 am 12:04 AM

Mengikat statik (statik: :) Melaksanakan pengikatan statik lewat (LSB) dalam PHP, yang membolehkan kelas panggilan dirujuk dalam konteks statik dan bukannya menentukan kelas. 1) Proses parsing dilakukan pada masa runtime, 2) Cari kelas panggilan dalam hubungan warisan, 3) ia boleh membawa overhead prestasi.

Apakah kaedah Magic PHP (__construct, __destruct, __call, __get, __set, dll) dan menyediakan kes penggunaan? Apakah kaedah Magic PHP (__construct, __destruct, __call, __get, __set, dll) dan menyediakan kes penggunaan? Apr 03, 2025 am 12:03 AM

Apakah kaedah sihir PHP? Kaedah sihir PHP termasuk: 1. \ _ \ _ Membina, digunakan untuk memulakan objek; 2. \ _ \ _ Destruct, digunakan untuk membersihkan sumber; 3. \ _ \ _ Call, mengendalikan panggilan kaedah yang tidak wujud; 4. \ _ \ _ Mendapatkan, melaksanakan akses atribut dinamik; 5. \ _ \ _ Set, melaksanakan tetapan atribut dinamik. Kaedah ini secara automatik dipanggil dalam situasi tertentu, meningkatkan fleksibiliti dan kecekapan kod.

See all articles