本篇文章向大家介绍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');
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。