Dalam PHP 8.1 dan lebih baru, mysqli mula secara automatik membuang pengecualian pada ralat, menghapuskan keperluan untuk manual pengendalian ralat. Penyimpangan daripada amalan lapuk untuk menyemak ralat secara manual dan mengeluarkan mesej tersuai mempunyai implikasi yang berbeza untuk pengendalian ralat dalam aplikasi anda.
Pendekatan lapuk, dicontohkan oleh if (!$conn), tidak lagi diperlukan atau dinasihatkan. Kedua-dua PDO dan mysqli kini mempunyai keupayaan untuk menimbulkan ralat secara automatik, sama seperti fungsi PHP yang lain. Oleh itu, kod semakan ralat eksplisit adalah berlebihan.
Menyembunyikan Mesej Ralat daripada Pengguna
Untuk menyembunyikan mesej ralat daripada pengguna, manfaatkan pilihan display_errors. Menetapkannya kepada 0 akan menyekat paparan sebarang ralat. Untuk kawalan yang terperinci, tetapkannya kepada 1 pada persekitaran pembangunan dan 0 pada pelayan langsung.
Halaman Ralat Tersuai untuk Situasi Luar Biasa
Pendekatan yang lebih mesra pengguna melibatkan memaparkan halaman ralat tersuai untuk ralat yang tidak boleh dipulihkan. Gunakan pengendali ralat untuk membalas semua ralat tersebut dengan mengelognya, menetapkan kod status HTTP kepada 500 dan memaparkan mesej ralat generik atau tersuai.
Menangkap Ralat Sambungan (Pilihan)
Untuk senario tertentu, seperti ujian kelayakan atau melaksanakan mekanisme sandaran, anda mungkin masih perlu menangkap secara eksplisit ralat sambungan menggunakan try..catch. Jika logik pengendalian ralat anda adalah berasingan daripada kod sambungan biasa anda, pendekatan ini sesuai.
Sebagai tindak balas kepada kebimbangan mengenai kata laluan pangkalan data yang muncul dalam surih tindanan, PHP 8.2 memperkenalkan penyelesaian . Pengendalian pengecualian yang dipertingkatkan menyembunyikan kata laluan daripada surih tindanan, meningkatkan keselamatan maklumat sensitif anda.
Atas ialah kandungan terperinci Mengapakah Mesej Ralat Tersuai untuk Kegagalan `mysqli_connect` Tidak Diperlukan Lagi dalam PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!