Rumah > rangka kerja php > Laravel > Bagaimana untuk menyelesaikan masalah ralat laravel

Bagaimana untuk menyelesaikan masalah ralat laravel

WBOY
Lepaskan: 2023-05-26 14:49:07
asal
999 orang telah melayarinya

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行日志是否包含"关键字"
Salin selepas log masuk

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

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

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('请求参数不正确');
    } 
}
Salin selepas log masuk

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

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!

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