首頁 > 後端開發 > php教程 > 利用debug_backtrace自訂個基本的日誌列印函數(PHP程式碼範例)

利用debug_backtrace自訂個基本的日誌列印函數(PHP程式碼範例)

藏色散人
發布: 2023-04-10 06:58:01
轉載
2705 人瀏覽過

本文時向大家介紹php基礎中使用程式碼範例,並使用 debug_backtrace 自訂基本的日誌列印函數,有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

利用debug_backtrace自訂個基本的日誌列印函數(PHP程式碼範例)

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

推薦:《PHP影片教學

在看別人的程式碼的時候發現了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');
登入後複製

以上是利用debug_backtrace自訂個基本的日誌列印函數(PHP程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
php
來源:learnku.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板