利用debug_backtrace自定义个基本的日志打印函数(PHP代码示例)
时间:2021-06-07 来源:互联网
今天PHP爱好者给大家带来利用debug_backtrace自定义个基本的日志打印函数(PHP代码示例),本篇文章向大家介绍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"]." 文件第行 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爱好者其它相关文章!
-
永劫无间多少钱一个红 2024-12-20
-
永劫无间多少钱开一个箱子 2024-12-20
-
阿瑞斯病毒2火铳弹药怎么获得?阿瑞斯病毒2火铳弹药获得方法 2024-12-19
-
阿瑞斯病毒2哈士奇在哪?阿瑞斯病毒2哈士奇获得方法 2024-12-19
-
寻道大千反击流阵容推荐 2024-12-19
-
和平精英性别怎么换?和平精英性别转换方法 2024-12-19