Rumah >rangka kerja php >Laravel >Bagaimana untuk menyelesaikan masalah ralat laravel
Semasa proses pembangunan menggunakan rangka kerja Laravel, pelbagai ralat atau pengecualian pasti akan berlaku. Cara cepat menyelesaikan ralat dan menyelesaikan masalah adalah cabaran yang dihadapi oleh pembangun asas. Artikel ini akan memperkenalkan anda kepada kaedah penyelesaian masalah untuk ralat Laravel dan membantu anda memperoleh dua kali ganda hasil dengan separuh usaha semasa proses pembangunan.
1. Pengelogan
Laravel akan merekodkan maklumat log dalam fail yang berbeza mengikut tahap yang berbeza (nyahpepijat, maklumat, notis, amaran, ralat, kritikal, amaran, kecemasan). Kita boleh mencari ralat dalam kod dengan cepat dengan melihat fail log.
1.1 Lihat fail log
Buka direktori storan/log dalam direktori akar projek, dan anda boleh melihat fail laravel.log Ini ialah jumlah fail log semua peringkat log masuk sistem. Jika anda ingin menggunakan tahap Berbeza tertentu boleh dikonfigurasikan dalam fail config/logging.php untuk mengumpul rekod log
Dalam fail log, anda boleh menapis dan melihat maklumat ralat berdasarkan masa, proses, tahap dan keadaan lain. Penggunaan khusus adalah seperti berikut:
tail -f storage/logs/laravel.log // 监控最新的日志内容,按Ctrl+C停止 cat storage/logs/laravel.log | grep '关键字' // 搜索包含"关键字"的日志内容 tail -n 100 storage/logs/laravel.log | grep '关键字' // 查看最后100行日志是否包含"关键字"
Tetapan tahap 1.2
Melalui apl direktori/Exceptions/Handler.php milik Laravel sendiri, anda boleh melihat bahawa tahap log ditetapkan dalam laporan() fungsi Dalam parameter pertama, tahap log lalai Laravel ialah ralat, yang bermaksud bahawa hanya log dengan tahap ralat dan ke atas akan direkodkan dalam fail log app/public/storage/logs/laravel.log.
Jika anda ingin menulis semua peringkat amaran dan log di atas ke fail log, anda boleh menambah tahap permulaan dalam parameter pertama fungsi report(), seperti yang ditunjukkan di bawah:
public function report(Exception $exception) { if ($this->shouldReport($exception)) { Log::channel('daily')->warning('遇到错误啦!', [ 'error' => $exception->getMessage() ]); } parent::report($exception); }
Melalui operasi Log::channel('daily')->warning(), maklumat ralat dan tahap ditulis pada log dan kaedah shouldReport() digunakan untuk menentukan sama ada ia perlu ditulis pada log.
2. Pengendalian pengecualian
Dalam aplikasi Laravel, cara untuk membuang pengecualian tersuai adalah sangat mudah, cuma lakukan perkara berikut:
2.1 Pengecualian tersuai
Cipta kelas pengecualian baharu dan warisi kelas Pengecualian lalai Laravel, seperti yang ditunjukkan di bawah:
namespace AppExceptions; use Exception; class CustomException extends Exception { public function __construct($message = null, $code = 0) { parent::__construct($message, $code); // 调用父类的构造方法 } public function report() { // 记录错误日志 Log::error('CustomException:'.$this->getMessage()); } public function render($request) { return response()->json(['message' => $this->getMessage()], Response::HTTP_INTERNAL_SERVER_ERROR); } }
Dalam pembina, kita boleh mentakrifkan maklumat pengecualian dan kod status, dan menambahnya dalam report() Log ralat direkodkan dalam kaedah, dan maklumat pengecualian serta kod status dalam format JSON dikembalikan dalam kaedah render().
Apabila CustomException berlaku dalam aplikasi, Laravel akan secara automatik melaksanakan kaedah report() untuk merekod maklumat ralat ke dalam fail log, dan mengembalikan maklumat pengecualian ke bahagian hadapan melalui kaedah render() untuk paparan .
2.2 Mencetuskan pengecualian
Gunakan kaedah lempar CustomException () baharu dalam kod untuk membuang pengecualian, seperti yang ditunjukkan di bawah:
public function test(Request $request) { // ... if (! check_validate($request->all())) { throw new CustomException('请求参数不正确'); } }
3 🎜>Apabila membangunkan atau menguji, kadangkala anda perlu menaip maklumat penyahpepijatan dalam kod untuk mencari masalah Dalam Laravel, kami boleh mengeluarkan maklumat penyahpepijatan dengan cepat dan mengganggu pelaksanaan program melalui hasil dump() dan dd().
3.1 dump() dan dd()
Fungsi dump() digunakan untuk mencetak kandungan pembolehubah atau tatasusunan tanpa mengganggu perjalanan atur cara. Sama seperti fungsi var_dump() terbina dalam PHP.
Fungsi dd() bukan sahaja akan mencetak kandungan pembolehubah atau tatasusunan, tetapi juga mengganggu pelaksanaan program dan memaparkan tindanan kod yang diproses ke kedudukan semasa dan maklumat khusus pengecualian. Sama seperti fungsi die() atau exit() terbina dalam PHP.
Route::get('/test', function () { dump('Hello Laravel!'); return response()->json(['key' => 'value']); }); Route::get('/test2', function () { $array = ['key_one' => 'value_one', 'key_two' => 'value_two']; dd($array); return response()->json(['key' => 'value']); });
Dalam kod di atas, kami menggunakan kaedah dump() dan dd() untuk mencetak kandungan rentetan dan tatasusunan Penggunaannya serupa dengan fungsi asli PHP, yang sangat mudah.
4. Kesimpulan
Semasa proses pembangunan Laravel, pelbagai mesej ralat akan sentiasa muncul atas pelbagai sebab. Cara menyelesaikan masalah dan menyelesaikan ralat ini dengan cekap adalah masalah yang mesti dihadapi oleh setiap pembangun. Dalam artikel ini, kami memperkenalkan beberapa kaedah penyelesaian masalah biasa seperti pengelogan Laravel, pengendalian pengecualian dan penyahpepijatan ralat Kami berharap ia akan membantu anda semasa membangunkan dalam Laravel.
Atas ialah kandungan terperinci Bagaimana untuk menyelesaikan masalah ralat laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!