您好,登錄后才能下訂單哦!
小編給大家分享一下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自定義個基本的日志打印函數”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。