首頁 > php教程 > PHP开发 > laravel中的錯誤與日誌用法詳解

laravel中的錯誤與日誌用法詳解

高洛峰
發布: 2016-12-23 17:21:34
原創
1421 人瀏覽過

本文實例講述了laravel中的錯誤與日誌用法。分享給大家參考,具體如下:

日誌

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

① 把monolog中的addInfo等函數簡化成為了info這樣的函數

② 增加了useFiles和useDailyFiles兩個參數,使得做日誌管理和切割變的容易了

③ 如果要呼叫monolog的方法需要呼叫callMonolog函數

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

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

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

<?php
use Monolog\Logger;
use Monolog\Handler\StreamHandler;
use Illuminate\Log\Writer;
class BLogger
{
  // 所有的LOG都要求在这里注册
  const LOG_ERROR = &#39;error&#39;;
  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().&#39;/logs/&#39;. $type .&#39;.log&#39;, $day);
    }
    $log = self::$loggers[$type];
    return $log;
  }
}
登入後複製

   

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

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

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

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

   

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

所以應該有的預設值把記錄成有的預設值。

同樣在start/global.php中

Log::useDailyFiles(storage_path().&#39;/logs/laravel.log&#39;, 30);
登入後複製

   

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

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

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

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

   

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

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

   

錯誤

laravel的所有錯誤會全部過global

錯誤

laravel的所有錯誤會全部過globalbal出來的App

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

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

   

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

App::missing(function($exception)
{
  $response = [
    &#39;status&#39; => 0,
    &#39;error&#39; => "请求路径错误",
  ];
  return Response::json($response);
});
登入後複製

 述對大家基於Laravel框架的PHP程式設計有所幫助。

更多laravel中的錯誤與日誌用法詳解相關文章請關注PHP中文網!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門推薦
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板