• 技术文章 >后端开发 >php教程

    利用debug_backtrace自定义个基本的日志打印函数(PHP代码示例)

    藏色散人藏色散人2021-05-31 09:39:39转载455

    本篇文章向大家介绍php基础常用代码示例,利用 debug_backtrace 自定义个基本的日志打印函数,有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

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

    推荐:《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中文网其它相关文章!

    声明:本文转载于:learnku,如有侵犯,请联系admin@php.cn删除
    专题推荐:php
    上一篇:整理常见的PHP算法面试题 下一篇:你对于PHP漏洞有哪些了解?(详细介绍)
    第16期线上培训班

    相关文章推荐

    • php数组怎么增加一个元素• php链式操作的实现方法有哪些• php常见报错级别有哪些• 你对PHP JSON函数有多少了解呢?• PHP7如何使用set_error_handler和set_exception_handler处理异常机制

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网