91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

laravel中錯誤與日志的示例分析

發布時間:2021-04-12 09:34:47 來源:億速云 閱讀:235 作者:小新 欄目:編程語言

小編給大家分享一下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 = '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中錯誤與日志的示例分析”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

望城县| 临桂县| 南华县| 磴口县| 江安县| 象州县| 五寨县| 西乡县| 南汇区| 清原| 华安县| 银川市| 丹巴县| 利辛县| 定日县| 自贡市| 河西区| 将乐县| 宁河县| 白山市| 漠河县| 华容县| 莱西市| 凌源市| 平顶山市| 曲阜市| 个旧市| 黑水县| 金秀| 同心县| 扎囊县| 枝江市| 哈密市| 普定县| 民权县| 乐清市| 南充市| 乾安县| 安阳市| 格尔木市| 林西县|