加入收藏 | 设为首页 | 会员中心 | 我要投稿 应用网_丽江站长网 (http://www.0888zz.com/)- 科技、建站、数据工具、云上网络、机器学习!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

借助debug_backtrace自定义个基本的日志打印函数

发布时间:2022-07-16 15:58:13 所属栏目:PHP教程 来源:互联网
导读:本篇文章向大家介绍php基础常用代码示例,利用 debug_backtrace 自定义个基本的日志打印函数,有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 最近在改一个古老祖传代码,可惜连个打印日志功能都没有,没有框架加持,才发现自己是多么的
  本篇文章向大家介绍php基础常用代码示例,利用 debug_backtrace 自定义个基本的日志打印函数,有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
 
  最近在改一个古老祖传代码,可惜连个打印日志功能都没有,没有框架加持,才发现自己是多么的弱鸡。
 
  推荐:《PHP视频教程》
 
  在看别人的代码的时候发现了php的这么个函数 debug_backtrace()着实解决了我的问题痛点,可以定义一个函数记录调用函数时的文件名和行数,从而知道对应的打印位置了。
 
  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)."nn";
 
      file_put_contents($file,$str,FILE_APPEND);
 
  }
 
   
 
  put_log('sss','ss/s/a.txt');

(编辑:应用网_丽江站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读