最近项目上线出现了问题,大量用户正在使用,找了半天原因,最终还是依靠打印打印日志文件,找到了错误出现的位置!所以,开发过程中,对可能出现错误的地方,打印日志是非常非常重要的一件事情!下面我就来详细讲下!
1、用到的函数file_put_contents()
file_put_contents() 函数把一个字符串写入文件中。
该函数访问文件时,遵循以下规则:
- 如果设置了 FILE_USE_INCLUDE_PATH,那么将检查 *filename* 副本的内置路径
- 如果文件不存在,将创建一个文件
- 打开文件
- 如果设置了 LOCK_EX,那么将锁定文件
- 如果设置了 FILE_APPEND,那么将移至文件末尾。否则,将会清除文件的内容
- 向文件中写入数据
- 关闭文件并对所有文件解锁
如果成功,该函数将返回写入文件中的字符数。如果失败,则返回 False。
语法
int file_put_contents ( string $filename , mixed $data [, int $flags = 0 [, resource $context ]] )
参数 | 描述 |
---|---|
file | 必需。规定要写入数据的文件。如果文件不存在,则创建一个新文件。 |
data | 必需。规定要写入文件的数据。可以是字符串、数组或数据流。 |
mode |
可选。规定如何打开/写入文件。可能的值:
|
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 版权协议,转载请附上原文出处链接和本声明。