小編給大家分享一下php中怎么利用debug_backtrace自定義個基本的日志打印函數(shù),相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
織金ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!
最近在改一個古老祖?zhèn)鞔a,可惜連個打印日志功能都沒有,沒有框架加持,才發(fā)現(xiàn)自己是多么的弱雞。
在看別人的代碼的時候發(fā)現(xiàn)了php的這么個函數(shù) debug_backtrace()著實解決了我的問題痛點,可以定義一個函數(shù)記錄調(diào)用函數(shù)時的文件名和行數(shù),從而知道對應(yīng)的打印位置了。
/** * 自定義日志打印,將日志信息寫入指定文件,并記錄當(dāng)前調(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)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!