Laravel 오류를 해결하는 방법

WBOY
풀어 주다: 2023-05-26 14:49:07
원래의
957명이 탐색했습니다.

Laravel 프레임워크를 사용하여 개발하는 과정에서는 필연적으로 다양한 오류나 예외가 발생하게 됩니다. 오류를 신속하게 해결하고 문제를 해결하는 방법은 기본 개발자가 직면한 과제입니다. 이 문서에서는 Laravel 오류에 대한 문제 해결 방법을 소개하고 개발 과정에서 절반의 노력으로 두 배의 결과를 얻을 수 있도록 도와줍니다.

1. 로깅

Laravel은 다양한 수준(디버그, 정보, 알림, 경고, 오류, 심각, 경고, 긴급)에 따라 다양한 파일에 로그 정보를 기록합니다. 로그 파일을 보면 코드의 오류를 빠르게 찾을 수 있습니다.

1.1 로그 파일 보기

프로젝트 루트 디렉터리에서 Storage/logs 디렉터리를 열면 laravel.log 파일을 볼 수 있습니다. 이는 시스템의 모든 로그 수준에 대한 전체 로그 파일입니다. 특정 수준의 로그 기록은 config/logging.php 파일에서 구성할 수 있습니다.

로그 파일에서 시간, 프로세스, 수준 및 기타 조건을 기준으로 오류 정보를 필터링하고 볼 수 있습니다. 구체적인 사용법은 다음과 같습니다.

tail -f storage/logs/laravel.log // 监控最新的日志内容,按Ctrl+C停止
cat storage/logs/laravel.log | grep '关键字' // 搜索包含"关键字"的日志内容
tail -n 100 storage/logs/laravel.log | grep '关键字' // 查看最后100行日志是否包含"关键字"
로그인 후 복사

1.2 레벨 설정

라라벨 자체 디렉토리 app/Exceptions/Handler.php 클래스를 통해 Report() 함수의 첫 번째 매개변수에 로그 레벨이 설정되어 있는 것을 볼 수 있으며, 라라벨은 기본적으로 로그 수준은 error입니다. 즉, 오류 수준 이상의 로그만 app/public/storage/logs/laravel.log 로그 파일에 기록됩니다.

모든 경고 수준 이상의 로그를 로그 파일에 기록하려면 아래와 같이 Report() 함수의 첫 번째 매개 변수에 시작 수준을 추가하면 됩니다.

public function report(Exception $exception)
{
    if ($this->shouldReport($exception)) {
        Log::channel('daily')->warning('遇到错误啦!', [
            'error' => $exception->getMessage()
        ]);
    }

    parent::report($exception);
}
로그인 후 복사

Through Log::channel('daily ')->warning() 연산을 수행하여 오류 정보와 수준을 로그에 기록하고, shouldReport() 메서드를 통해 로그에 기록해야 하는지 여부를 결정합니다.

2. 예외 처리

Laravel 애플리케이션에서 사용자 정의 예외를 발생시키는 방법은 매우 간단합니다. 다음을 수행하세요.

2.1 사용자 정의 예외

아래 표시된 대로 새 예외 클래스를 만들고 Laravel 기본 예외 클래스를 상속합니다. :

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);
    }
}
로그인 후 복사

생성 메소드에서는 예외 정보와 상태 코드를 정의하고, report() 메소드에 오류 로그를 기록하고, render() 메소드 코드에 예외 정보와 상태를 JSON 형식으로 반환할 수 있습니다.

애플리케이션에서 CustomException이 발생하면 Laravel은 자동으로 Report() 메서드를 실행하여 오류 정보를 로그 파일에 기록하고, render() 메서드를 통해 예외 정보를 프런트 엔드에 반환합니다.

2.2 예외 트리거

아래와 같이 코드에서 throw new CustomException() 메서드를 사용하여 예외를 발생시킵니다.

public function test(Request $request)
{
    // ...
    if (! check_validate($request->all())) {
        throw new CustomException('请求参数不正确');
    } 
}
로그인 후 복사

3. 오류 디버깅

개발 또는 테스트할 때 코드에 디버깅을 입력해야 하는 경우가 있습니다. 문제를 쉽게 찾을 수 있도록 정보를 제공하고, Laravel에서는 dump(), dd() 함수를 통해 디버깅 정보와 프로그램 실행 결과를 빠르게 출력할 수 있습니다.

3.1 dump() 및 dd()

dump() 함수는 프로그램 실행을 중단하지 않고 변수나 배열의 내용을 인쇄하는 데 사용됩니다. PHP 내장 var_dump() 함수와 유사합니다.

dd() 함수는 변수나 배열의 내용을 출력할 뿐만 아니라 프로그램의 실행을 중단하고 현재 위치까지 처리된 코드 스택과 예외의 구체적인 정보를 표시합니다. PHP에 내장된 die() 또는 exit() 함수와 유사합니다.

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']);
});
로그인 후 복사

위 코드에서는 dump() 및 dd() 메서드를 사용하여 문자열과 배열의 내용을 인쇄합니다. 사용법은 PHP 기본 함수와 유사하여 매우 편리합니다.

4. 결론

Laravel의 개발 과정에서는 다양한 이유로 인해 항상 다양한 오류 메시지가 나타납니다. 이러한 오류를 효율적으로 해결하는 방법은 모든 개발자가 직면해야 하는 문제입니다. 이 글에서는 Laravel 로깅, 예외 처리, 오류 디버깅과 같은 몇 가지 일반적인 문제 해결 방법을 소개합니다. Laravel에서 개발할 때 도움이 되기를 바랍니다.

위 내용은 Laravel 오류를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿