下面由laravel教學欄位來介紹laravel中的錯誤與日誌(可以自訂日誌目錄和log檔名),希望對需要的朋友有幫助!
日誌
#laravel中的日誌是基於monolog而封裝的。 laravel在它上面做了幾個事情:
好了,看看下面幾個需求怎麼實現:
這個需求很普遍的,例如呼叫訂單的日誌,需要記錄到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; } }
這樣不同的日誌資料會被儲存到不同的日誌檔案中去。還能記錄日誌資料資訊。
使用上面的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中文網其他相關文章!