laravel中的錯(cuò)誤與日志用法詳解
本文實(shí)例講述了laravel中的錯(cuò)誤與日志用法。分享給大家供大家參考,具體如下:
日志
laravel中的日志是基于monolog而封裝的。laravel在它上面做了幾個(gè)事情:
① 把monolog中的addInfo等函數(shù)簡(jiǎn)化成為了info這樣的函數(shù)
② 增加了useFiles和useDailyFiles兩個(gè)參數(shù),使得做日志管理和切割變的容易了
③ 如果要調(diào)用monolog的方法需要調(diào)用callMonolog函數(shù)
好了,看下下面幾個(gè)需求怎么實(shí)現(xiàn):
將不同的日志信息存放到不同的日志中去
這個(gè)需求很普遍的,比如調(diào)用訂單的日志,需要記錄到order.log,獲取店鋪信息的記錄需要記錄到shop.log中去??梢赃@么做:
<?php use Monolog\Logger; use Monolog\Handler\StreamHandler; use Illuminate\Log\Writer; class BLogger { // 所有的LOG都要求在這里注冊(cè) const LOG_ERROR = 'error'; private static $loggers = array(); // 獲取一個(gè)實(shí)例 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ù)會(huì)被存儲(chǔ)到不同的日志文件中去。還能記錄日志數(shù)據(jù)信息。
laravel的錯(cuò)誤日志堆棧太長(zhǎng)了,怎么辦?
使用上面的BLogger類,在start/global.php記錄下必要的錯(cuò)誤信息
// 錯(cuò)誤日志信息 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默認(rèn)的日志沒(méi)有使用分割
所以應(yīng)該默認(rèn)把laravel的默認(rèn)日志記錄改成有分割的。
同樣在start/global.php中
Log::useDailyFiles(storage_path().'/logs/laravel.log', 30);
如何記錄一個(gè)請(qǐng)求的sql日志
這個(gè)應(yīng)該再細(xì)化問(wèn),你是不是要實(shí)時(shí)記錄?
如果不要實(shí)時(shí)記錄,那么laravel有個(gè)DB::getQueryLog可以獲取一個(gè)app請(qǐng)求獲取出來(lái)的sql請(qǐng)求:
## 在filters.php中 App::after(function($request, $response) { // 數(shù)據(jù)庫(kù)查詢進(jìn)行日志 $queries = DB::getQueryLog(); if (Config::get('query.log', false)) { BLogger::getLogger('query')->info($queries); } }
如果你是需要實(shí)時(shí)記錄的(也就是你在任何地方die出來(lái)的時(shí)候,之前的頁(yè)面的sql請(qǐng)求也有記錄)的話,你就需要監(jiān)聽(tīng)illuminate.query事件了
// 數(shù)據(jù)庫(kù)實(shí)時(shí)請(qǐng)求的日志 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); }); }
錯(cuò)誤
laravel的所有錯(cuò)誤會(huì)全部過(guò)global的App::error再出來(lái)
所以比如你設(shè)計(jì)的是接口,希望即使有error出現(xiàn)也返回json數(shù)據(jù),則可以這么做:
// 錯(cuò)誤日志信息 App::error(function(Exception $exception, $code) { // 如果沒(méi)有路徑就直接跳轉(zhuǎn)到登錄頁(yè)面 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' => "服務(wù)器內(nèi)部錯(cuò)誤", ]; return Response::json($response); });
如果你還希望將404錯(cuò)誤也hold?。?/p>
App::missing(function($exception) { $response = [ 'status' => 0, 'error' => "請(qǐng)求路徑錯(cuò)誤", ]; return Response::json($response); });
更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門(mén)與進(jìn)階教程》、《php優(yōu)秀開(kāi)發(fā)框架總結(jié)》、《smarty模板入門(mén)基礎(chǔ)教程》、《php日期與時(shí)間用法總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家基于Laravel框架的PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
php workerman定時(shí)任務(wù)的實(shí)現(xiàn)代碼
這篇文章主要介紹了php workerman定時(shí)任務(wù)的實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12Laravel中數(shù)據(jù)遷移與數(shù)據(jù)填充的詳細(xì)步驟
這篇文章主要給大家介紹了關(guān)于Laravel中數(shù)據(jù)遷移與數(shù)據(jù)填充的相關(guān)資料,文中通過(guò)示例代碼給大家詳細(xì)介紹了實(shí)現(xiàn)的步驟,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起看看吧。2017-12-12php+ajax 實(shí)現(xiàn)輸入讀取數(shù)據(jù)庫(kù)顯示匹配信息
這篇文章主要介紹了php+ajax 實(shí)現(xiàn)輸入讀取數(shù)據(jù)庫(kù)顯示匹配信息的相關(guān)資料,需要的朋友可以參考下2015-10-10發(fā)布一個(gè)迷你php+AJAX聊天程序[聊天室]提供下載
發(fā)布一個(gè)迷你php+AJAX聊天程序[聊天室]提供下載...2007-07-07一個(gè)自定義位數(shù)的php多用戶計(jì)數(shù)器代碼
一個(gè)自定義位數(shù)的php多用戶計(jì)數(shù)器代碼...2007-03-03PHP實(shí)現(xiàn)單條sql執(zhí)行多個(gè)數(shù)據(jù)的insert語(yǔ)句方法
今天小編就為大家分享一篇PHP實(shí)現(xiàn)單條sql執(zhí)行多個(gè)數(shù)據(jù)的insert語(yǔ)句方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10Yii2 rbac權(quán)限控制操作步驟實(shí)例教程
這篇文章主要介紹了Yii2 rbac權(quán)限控制操作步驟實(shí)例教程的相關(guān)資料,需要的朋友可以參考下2016-04-04