成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? laravel中的錯誤與日志用法詳解
全站頭部文字 我要出現在這里
laravel中的錯誤與日志用法詳解 676 2024-01-28   

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

日志

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

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

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

③ 如果要調用monolog的方法需要調用callMonolog函數

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

將不同的日志信息存放到不同的日志中去

這個需求很普遍的,比如調用訂單的日志,需要記錄到order.log,獲取店鋪信息的記錄需要記錄到shop.log中去。可以這么做:

<?php 
use MonologLogger;
use MonologHandlerStreamHandler;
use IlluminateLogWriter;
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;
  }
}

這樣不同的日志數據會被存儲到不同的日志文件中去。還能記錄日志數據信息。

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相關內容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優秀開發框架總結》、《smarty模板入門基礎教程》、《php日期與時間用法總結》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家基于Laravel框架的PHP程序設計有所幫助。



主站蜘蛛池模板: 极寒之城剧情详细介绍| 香帅传奇| 打开双腿扒开打屁股羞辱惩罚视频| 髋关节置换术后护理ppt| 电影后妈| 100克米饭多大一碗图片| 色戒在线视频观看| 妙探出差3| 脓毒血症护理查房ppt| 李保国电影| 演觉法师| run on| 袁隆平电影| 夫妻情感生活| 100张照片| 若月玛丽亚| 地理填充图册| 恶行之外电影| 80年代欧美动画片| 山西少儿频道| 少年派1主演名单| 有氧运动有哪些项目| 风云雄霸天下| 日本大片ppt免费ppt电影| 维尼琼斯| 纵横欲海| 欲海情缘| 吴京电影全集完整版喜剧| 女老板| 杨玉环一级片| coco电影| 一级毛片色一级| 宅基地买卖合同协议书| 李乃文电影| 张凤妮| 相声剧本(适合学生)| 苏西| 教育在线教育平台直播| 大雄的恐龙| 国产精品欧美大片| 江南好简谱|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103