线上环境打印日志非常非常重要!PHP如何封装一个打印日志方法?

  • Post author:
  • Post category:php


最近项目上线出现了问题,大量用户正在使用,找了半天原因,最终还是依靠打印打印日志文件,找到了错误出现的位置!所以,开发过程中,对可能出现错误的地方,打印日志是非常非常重要的一件事情!下面我就来详细讲下!


1、用到的函数file_put_contents()

file_put_contents() 函数把一个字符串写入文件中。

该函数访问文件时,遵循以下规则:

  1. 如果设置了 FILE_USE_INCLUDE_PATH,那么将检查 *filename* 副本的内置路径
  2. 如果文件不存在,将创建一个文件
  3. 打开文件
  4. 如果设置了 LOCK_EX,那么将锁定文件
  5. 如果设置了 FILE_APPEND,那么将移至文件末尾。否则,将会清除文件的内容
  6. 向文件中写入数据
  7. 关闭文件并对所有文件解锁

如果成功,该函数将返回写入文件中的字符数。如果失败,则返回 False。

语法

int file_put_contents ( string $filename , mixed $data [, int $flags = 0 [, resource $context ]] )
参数 描述
file 必需。规定要写入数据的文件。如果文件不存在,则创建一个新文件。
data 必需。规定要写入文件的数据。可以是字符串、数组或数据流。
mode 可选。规定如何打开/写入文件。可能的值:

  • FILE_USE_INCLUDE_PATH
  • FILE_APPEND
  • LOCK_EX
context 可选。规定文件句柄的环境。context 是一套可以修改流的行为的选项。


2、封装日志文件makeLog()方法

<?php
/**
 * 声明文件日志
 * @param string $type
 * @param string $data
 */
public function makeLog($type='',$data=''){
  if(!empty($type)){
  // 'DIR_LOG'=>'/home/www/ymd/public/ymd/logs/'

 @file_put_contents(C('DIR_LOG').$type."/".$type.'_'.date('YmdH').'.txt',$data."\n",FILE_APPEND);
 }
}

//调用文件日志
 $this->makeLog('ymd','日志记录');



版权声明:本文为Aaroun原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。