网站建设资讯

NEWS

网站建设资讯

php中怎么利用debug_backtrace自定义个基本的日志打印函数

小编给大家分享一下php中怎么利用debug_backtrace自定义个基本的日志打印函数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

织金ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:18980820575(备注:SSL证书合作)期待与您的合作!

                           

最近在改一个古老祖传代码,可惜连个打印日志功能都没有,没有框架加持,才发现自己是多么的弱鸡。

在看别人的代码的时候发现了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自定义个基本的日志打印函数”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


网站栏目:php中怎么利用debug_backtrace自定义个基本的日志打印函数
新闻来源:http://cdweb.net/article/joshdi.html