溫馨提示×

溫馨提示×

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

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

php中怎么利用debug_backtrace自定義個基本的日志打印函數(shù)

發(fā)布時間:2021-05-31 10:42:24 來源:億速云 閱讀:119 作者:小新 欄目:編程語言

小編給大家分享一下php中怎么利用debug_backtrace自定義個基本的日志打印函數(shù),相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

                           

最近在改一個古老祖?zhèn)鞔a,可惜連個打印日志功能都沒有,沒有框架加持,才發(fā)現(xiàn)自己是多么的弱雞。

在看別人的代碼的時候發(fā)現(xiàn)了php的這么個函數(shù) debug_backtrace()著實解決了我的問題痛點,可以定義一個函數(shù)記錄調(diào)用函數(shù)時的文件名和行數(shù),從而知道對應的打印位置了。

/**
 * 自定義日志打印,將日志信息寫入指定文件,并記錄當前調(diào)用的文件名與行數(shù)
 * @param $data mixed 寫入文件的數(shù)據(jù)
 * @param $file string 文件路徑
 */
function put_log($data,$file){

    // 遞歸創(chuàng)建文件夾
    function created_dir( $dir ){
        return  is_dir ( $dir ) or created_dir(dirname( $dir )) and  mkdir ( $dir , 0777);
    }

    $traces = debug_backtrace();

    if(dirname($file)!='.'){
        created_dir( dirname($file) );
    }

    $str = date('Y-m-d H:i:s')."\n";
    foreach ($traces as $trace){
        $str .= $trace["file"]." 文件第【".$trace["line"]."】行 data:\n";
    }
    $str .= json_encode($data)."\n\n";

    file_put_contents($file,$str,FILE_APPEND);
}

put_log('sss','ss/s/a.txt');

以上是“php中怎么利用debug_backtrace自定義個基本的日志打印函數(shù)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

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

AI