laravel中的錯誤與日志用法詳解
本文實例講述了laravel中的錯誤與日志用法。分享給大家供大家參考,具體如下:
日志
laravel中的日志是基于monolog而封裝的。laravel在它上面做了幾個事情:
① 把monolog中的addInfo等函數(shù)簡化成為了info這樣的函數(shù)
② 增加了useFiles和useDailyFiles兩個參數(shù),使得做日志管理和切割變的容易了
③ 如果要調(diào)用monolog的方法需要調(diào)用callMonolog函數(shù)
好了,看下下面幾個需求怎么實現(xiàn):
將不同的日志信息存放到不同的日志中去
這個需求很普遍的,比如調(diào)用訂單的日志,需要記錄到order.log,獲取店鋪信息的記錄需要記錄到shop.log中去??梢赃@么做:
<?php
use Monolog\Logger;
use Monolog\Handler\StreamHandler;
use Illuminate\Log\Writer;
class BLogger
{
// 所有的LOG都要求在這里注冊
const LOG_ERROR = 'error';
private static $loggers = array();
// 獲取一個實例
public static function getLogger($type = self::LOG_ERROR, $day = 30)
{
if (empty(self::$loggers[$type])) {
self::$loggers[$type] = new Writer(new Logger($type));
self::$loggers[$type]->useDailyFiles(storage_path().'/logs/'. $type .'.log', $day);
}
$log = self::$loggers[$type];
return $log;
}
}
這樣不同的日志數(shù)據(jù)會被存儲到不同的日志文件中去。還能記錄日志數(shù)據(jù)信息。
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)
{
// 數(shù)據(jù)庫查詢進行日志
$queries = DB::getQueryLog();
if (Config::get('query.log', false)) {
BLogger::getLogger('query')->info($queries);
}
}
如果你是需要實時記錄的(也就是你在任何地方die出來的時候,之前的頁面的sql請求也有記錄)的話,你就需要監(jiān)聽illuminate.query事件了
// 數(shù)據(jù)庫實時請求的日志
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出現(xiàn)也返回json數(shù)據(jù),則可以這么做:
// 錯誤日志信息
App::error(function(Exception $exception, $code)
{
// 如果沒有路徑就直接跳轉(zhuǎn)到登錄頁面
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' => "服務器內(nèi)部錯誤",
];
return Response::json($response);
});
如果你還希望將404錯誤也hold?。?/p>
App::missing(function($exception)
{
$response = [
'status' => 0,
'error' => "請求路徑錯誤",
];
return Response::json($response);
});
更多關于Laravel相關內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優(yōu)秀開發(fā)框架總結》、《smarty模板入門基礎教程》、《php日期與時間用法總結》、《php面向?qū)ο蟪绦蛟O計入門教程》、《php字符串(string)用法總結》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設計有所幫助。
相關文章
PHP二維關聯(lián)數(shù)組的遍歷方式(實例講解)
下面小編就為大家?guī)硪黄狿HP二維關聯(lián)數(shù)組的遍歷方式(實例講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10
laravel withCount 統(tǒng)計關聯(lián)數(shù)量的方法
今天小編就為大家分享一篇laravel withCount 統(tǒng)計關聯(lián)數(shù)量的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
PHP數(shù)組的基本操作及遍歷數(shù)組的經(jīng)典操作實例
下面小編就為大家?guī)硪黄狿HP數(shù)組的基本操作及遍歷數(shù)組的經(jīng)典操作實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08
Thinkphp調(diào)用Image類生成縮略圖的方法
這篇文章主要介紹了Thinkphp調(diào)用Image類生成縮略圖的方法,實例分析了Thinkphp調(diào)用Image類生成縮略圖的使用原理與相關技巧,需要的朋友可以參考下2015-03-03

