中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

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

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

                           

最近在改一個古老祖傳代碼,可惜連個打印日志功能都沒有,沒有框架加持,才發現自己是多么的弱雞。

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

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

    // 遞歸創建文件夾
    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自定義個基本的日志打印函數”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

AI

邵东县| 东光县| 曲阳县| 循化| 克拉玛依市| 邓州市| 涿州市| 双柏县| 兴城市| 浦县| 上栗县| 徐水县| 通州市| 赤壁市| 隆德县| 曲阳县| 安吉县| 南溪县| 洱源县| 巧家县| 镇雄县| 南澳县| 施甸县| 吴川市| 灌云县| 尚义县| 刚察县| 康乐县| 芒康县| 望谟县| 清丰县| 古交市| 千阳县| 安溪县| 资讯| 晋宁县| 肥西县| 织金县| 静安区| 尖扎县| 奇台县|