PHP调试函数和日志记录函数分享

 更新时间:2015年01月31日 11:59:06   投稿:junjie  
这篇文章主要介绍了PHP调试函数和日志记录函数分享,本文分享的函数都是自己项目中使用的,需要的朋友可以参考下

网站程序开发过程经常需要调试,发布阶段也需要记录运行日志,方便发现问题和还原事件。这就要求有调试和日志记录功能。

下面分别写了用于调试的函数和用于记录错误的函数。

使用方法很简单,且自动根据日期生成日志文件:

复制代码 代码如下:

//调试时,多个参数都可以:
sysdebug("hello");
sysdebug("hello", "tiger is coming now");

//错误记录也一样:
syserror("error");
syserror("error", "unfortunately tiger is dead ", "we are sad");

php调试和日志记录函数,如下:

复制代码 代码如下:

/**
 * 记录调试信息
 */ 
function sysdebug($msg) { 
  if (defined("DEBUG_MODE")) { 
    //TODO 检测调试开关,发布时不打印 
    $params = func_get_args(); 
    $traces = debug_backtrace(); 
    $trace = array_pop($traces); 
    sysrecord($params, $trace, 'debug'); 
  } 

 
/**
 * 记录错误信息
 */ 
function syserror($msg) { 
  $params = func_get_args(); 
  $traces = debug_backtrace(); 
  $trace = array_pop($traces); 
  sysrecord($params, $trace, 'error'); 

 
/**
 * 写文件
 * @ignore
 */ 
function sysfile($filename, $msg, $mode = null) { 
  $path = dirname($filename); 
  if (!file_exists($path)) { 
    mkdir($path, 0666, true); 
  } 
  $flag = LOCK_EX; 
  if ($mode) { 
    switch ($mode) { 
      case "add": 
        $flag = FILE_APPEND | LOCK_EX; 
        break; 
      case "a": 
        $flag = FILE_APPEND | LOCK_EX; 
        break; 
      default: 
        break; 
    } 
  } 
  file_put_contents($filename, $msg, $flag); 

 
/**
 * 记录信息
 * @ignore
 */ 
function sysrecord($params, $trace, $level) { 
  $path = dirname(__FILE__) . "/logs/"; 
  //TODO 日志保存目录最好修改一下 
   
  $file = $trace['file']; 
  $func = $trace['function']; 
  if ($func == "sys$level") { 
    $func = ''; 
  } 
  $filename = $path . "$level/" . date("Y-m-d") . '.log'; 
  $msg = "[" . date("m-d H:i:s") . "] File:\"" . basename($file) . "\" Func:\"" . $func . "\" Msg:" . json_encode($params) . "\r\n"; 
  sysfile($filename, $msg, 'add'); 

相关文章

  • PHP 文件上传源码分析(RFC1867)

    PHP 文件上传源码分析(RFC1867)

    文件上传,一般分为俩种方式FTP和HTTP, 对于我们的互联网应用来说: FTP上传虽然传输稳定, 但是易用性和安全性都是个问题.
    2009-10-10
  • 一个数据采集类

    一个数据采集类

    一个数据采集类...
    2007-02-02
  • PHP实现文件上传与下载的示例代码

    PHP实现文件上传与下载的示例代码

    这篇文章主要为大家详细介绍了PHP实现文件上传与下载功能的相关知识,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2023-12-12
  • php图片上传类 附调用方法

    php图片上传类 附调用方法

    这篇文章主要为大家分享了一个php上传图片的类,文中附调用方法,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • PHP对二维数组(多维数组)进行排序的方法

    PHP对二维数组(多维数组)进行排序的方法

    在 PHP 中,可以使用函数 array_multisort() 来对二维数组进行排序处理,该函数可以按照指定的键或值对数组进行排序,本文通过一个示例来给大家介绍一下PHP如何对二维数组(多维数组)进行排序,需要的朋友可以参考下
    2023-09-09
  • php文件上传的两种实现方法

    php文件上传的两种实现方法

    这篇文章主要为大家详细介绍了两种php文件上传的实现方法,感兴趣的朋友可以参考一下
    2016-04-04
  • PHP一致性hash分布式算法封装类定义与用法示例

    PHP一致性hash分布式算法封装类定义与用法示例

    这篇文章主要介绍了PHP一致性hash分布式算法封装类定义与用法,结合完整实例形式分析了一致性hash分布式算法的原理、实现及使用方法,需要的朋友可以参考下
    2018-08-08
  • PHP设计模式之模板方法模式实例浅析

    PHP设计模式之模板方法模式实例浅析

    这篇文章主要介绍了PHP设计模式之模板方法模式,结合实例形式简单分析了php设计模式中模板方法模式的概念、原理、定义、使用方法及相关操作注意事项,需要的朋友可以参考下
    2018-12-12
  • 一个好用的分页函数

    一个好用的分页函数

    [红色]一个好用的分页函数...
    2006-11-11
  • 国外PHP程序员的13个好习惯小结

    国外PHP程序员的13个好习惯小结

    我是一个PHP新手,只有6个月的PHP编程经历,并且是在一位经过认证的zend工程师的指导下完成工作的,每当我编写脚本时,我会注意一些能让我做得更好的细节
    2012-02-02

最新评论