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

溫馨提示×

溫馨提示×

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

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

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

阿勒泰市| 安泽县| 安吉县| 英吉沙县| 抚顺县| 云和县| 连云港市| 延寿县| 盱眙县| 淳化县| 贵南县| 萨嘎县| 定州市| 华容县| 包头市| 洪泽县| 年辖:市辖区| 临高县| 长子县| 泌阳县| 梁平县| 沧州市| 运城市| 潜江市| 麻江县| 五峰| 山阴县| 屏东市| 天镇县| 革吉县| 洛扎县| 通城县| 利辛县| 平阳县| 漯河市| 綦江县| 云南省| 汾阳市| 神池县| 曲麻莱县| 仁化县|