Home > php教程 > PHP开发 > body text

Detailed explanation of error and log usage in laravel

高洛峰
Release: 2016-12-23 17:21:34
Original
1334 people have browsed it

The examples in this article describe the usage of errors and logs in laravel. Share it with everyone for your reference, the details are as follows:

Logs

The logs in laravel are encapsulated based on monolog. Laravel has done several things on it:

① Simplified functions such as addInfo in monolog into functions like info

② Added two parameters, useFiles and useDailyFiles, making log management and cutting easier

③ If you want to call the monolog method, you need to call the callMonolog function

Okay, let’s see how to implement the following requirements:

Store different log information in different logs

This requirement is very common, such as calling The order log needs to be recorded in order.log, and the record of obtaining store information needs to be recorded in shop.log. You can do this:

<?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;
  }
}
Copy after login

In this way, different log data will be stored in different log files. Log data information can also be recorded.

Laravel’s error log stack is too long, what should I do?

Use the above Blogger class and record the necessary error information in 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);
});
Copy after login

Laravel’s default log does not use segmentation

So laravel’s default logging should be changed to segmentation by default .

Also in start/global.php

Log::useDailyFiles(storage_path().&#39;/logs/laravel.log&#39;, 30);
Copy after login

How to record the sql log of a request

This should be further refined. Do you want to record it in real time?

If you don’t want real-time recording, then laravel has DB::getQueryLog to get the sql request obtained by an app request:

## 在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);
  }
}
Copy after login

If you need real-time recording (that is, you die anywhere time, the sql request of the previous page is also recorded), you need to listen to the illuminate.query event

// 数据库实时请求的日志
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);
  });
}
Copy after login

Error

All errors in laravel will all go through the global App::error and then come out

So For example, if you design an interface and want to return json data even if an error occurs, you can do this:

// 错误日志信息
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);
});
Copy after login

If you also want to hold the 404 error:

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

I hope this article will help you. The above will be helpful to everyone in PHP programming based on the Laravel framework.

For more detailed explanations of errors and log usage in laravel, please pay attention to the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Recommendations
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!