首頁  >  文章  >  php框架  >  關於laravel中的錯誤與日誌

關於laravel中的錯誤與日誌

藏色散人
藏色散人原創
2021-04-09 13:46:332170瀏覽

下面由laravel教學欄位來介紹laravel中的錯誤與日誌(可以自訂日誌目錄和log檔名),希望對需要的朋友有幫助!

關於laravel中的錯誤與日誌

日誌

#laravel中的日誌是基於monolog而封裝的。 laravel在它上面做了幾個事情:

  • 把monolog中的addInfo等函數簡化成為了info這樣的函數
  • 增加了useFiles和useDailyFiles兩個參數,使得做日誌管理和切割變的容易了
  • 如果要呼叫monolog的方法需要呼叫callMonolog函數

好了,看看下面幾個需求怎麼實現:

將不同的日誌資訊存放到不同的日誌中去

這個需求很普遍的,例如呼叫訂單的日誌,需要記錄到order.log,取得店鋪資訊的記錄需要記錄到shop.log中去。可以這麼做:

useDailyFiles(storage_path().'/logs/'. $type .'.log', $day);
        }
 
        $log = self::$loggers[$type];
        return $log;
    }
}

這樣不同的日誌資料會被儲存到不同的日誌檔案中去。還能記錄日誌資料資訊。

laravel的錯誤日誌堆疊太長了,怎麼辦?

使用上面的BLogger類,在start/global.php記錄下必要的錯誤訊息

// 错误日志信息
App::error(function(Exception $exception, $code)
{
    Log::error($exception);
 
    $err = [
        'message' => $exception->getMessage(),
        'file' => $exception->getFile(),
        'line' => $exception->getLine(),
        'code' => $exception->getCode(),
        'url' => Request::url(),
        'input' => Input::all(),
    ];
    BLogger::getLogger(BLogger::LOG_ERROR)->error($err);
});

 laravel預設的日誌沒有使用分割

#所以應該預設把laravel的預設日誌記錄改成有分割的。

同樣在start/global.php中

Log::useDailyFiles(storage_path().'/logs/laravel.log', 30);

 如何記錄一個請求的sql日誌

這個應該再細化問,你是不是要即時記錄?

如果不要即時記錄,那麼laravel有個DB::getQueryLog可以取得app請求取得出來的sql請求:

## 在filters.php中
App::after(function($request, $response)
{
    // 数据库查询进行日志
    $queries = DB::getQueryLog();
    if (Config::get('query.log', false)) {
        BLogger::getLogger('query')->info($queries);
    }
}

如果你是需要即時記錄的(也就是你在任何地方die出來的時候,之前的頁面的sql請求也有記錄)的話,你就需要監聽illuminate.query事件了

// 数据库实时请求的日志
if (Config::get('database.log', false))
{
    Event::listen('illuminate.query', function($query, $bindings, $time, $name)
    {
        $data = compact('query','bindings', 'time', 'name');
        BLogger::getLogger(BLogger::LOG_QUERY_REAL_TIME)->info($data);
    });
}

 錯誤

#laravel的所有錯誤都會全部過global的App::error再出來

所以比如你設計的是接口,希望即使有error出現也返回json數據,則可以這麼做:

// 错误日志信息
App::error(function(Exception $exception, $code)
{
    // 如果没有路径就直接跳转到登录页面
    if ($exception instanceof NotFoundHttpException) {
        return Redirect::route('login');
    }
 
    Log::error($exception);
 
    $err = [
        'message' => $exception->getMessage(),
        'file' => $exception->getFile(),
        'line' => $exception->getLine(),
        'code' => $exception->getCode(),
        'url' => Request::url(),
        'input' => Input::all(),
    ];
    BLogger::getLogger(BLogger::LOG_ERROR)->error($err);
 
    $response = [
        'status' => 0,
        'error' => "服务器内部错误",
    ];
    return Response::json($response);
});

如果你還希望將404錯誤也hold住:

App::missing(function($exception)
{
    $response = [
        'status' => 0,
        'error' => "请求路径错误",
    ];
    return Response::json($response);
});

以上是關於laravel中的錯誤與日誌的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn