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'); 

相关文章

  • Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存

    Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存

    这篇文章主要介绍了Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存,本文扩展了一个支持SASL 认证模式的Memcached缓存驱动,需要的朋友可以参考下
    2015-02-02
  • php 远程关机操作的代码

    php 远程关机操作的代码

    远程启动计算机 注意:iis/apache需要有windows/system/cmd.exe执行权限 name:薛如飞
    2008-12-12
  • PHP中使用file_get_contents抓取网页中文乱码问题解决方法

    PHP中使用file_get_contents抓取网页中文乱码问题解决方法

    这篇文章主要介绍了PHP中使用file_get_contents抓取网页中文乱码问题解决方法,可以通过使用curl配置gzip选项来解决,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-12-12
  • SAE实时日志接口SDK用法示例

    SAE实时日志接口SDK用法示例

    这篇文章主要介绍了SAE实时日志接口SDK用法,结合实例形式分析了PHP版本的接口调用SDK及相应的使用方法,需要的朋友可以参考下
    2016-10-10
  • 获取远程文件大小的php函数

    获取远程文件大小的php函数

    用php实现获取远程文件大小的代码,需要的朋友可以参考下。
    2010-01-01
  • PHP进阶学习之Geo的地图定位算法详解

    PHP进阶学习之Geo的地图定位算法详解

    这篇文章主要介绍了PHP进阶学习之Geo的地图定位算法,结合实例形式详细分析了php Geo的地图定位算法相关概念、原理、实现方法与操作注意事项,需要的朋友可以参考下
    2019-06-06
  • php/JS实现的生成随机密码(验证码)功能示例

    php/JS实现的生成随机密码(验证码)功能示例

    这篇文章主要介绍了php/JS实现的生成随机密码(验证码)功能,结合实例形式分析了php与javascript随机字符串生成相关的字符串遍历、随机数生成、编码转换等操作技巧,需要的朋友可以参考下
    2019-06-06
  • php防止sql注入之过滤分页参数实例

    php防止sql注入之过滤分页参数实例

    这篇文章主要介绍了php防止sql注入中过滤分页参数的方法,实例展示了针对分页参数的数值判断问题,是非常具有实用价值的技巧,需要的朋友可以参考下
    2014-11-11
  • 通用PHP动态生成静态HTML网页的代码

    通用PHP动态生成静态HTML网页的代码

    最近研究PHP的一些开发技术,发现PHP有很多ASP所没有的优秀功能,可以完成一些以前无法完成的功能,例如动态生成HTML静态页面,以减少服务器CPU的负载,提高用户访问的速度。
    2010-03-03
  • PHP中PDO事务处理操作示例

    PHP中PDO事务处理操作示例

    这篇文章主要介绍了PHP中PDO事务处理操作,结合实例形式分析了php使用pdo的mysql事务处理操作步骤、实现技巧及相关注意事项,需要的朋友可以参考下
    2018-05-05

最新评论