PHP如何封装打印日志的方法(附代码)

不言
不言 原创
2023-04-03 21:04:02 3061浏览

本篇文章给大家带来的内容是关于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','日志记录');

相关推荐:

php如何实现保存网络图片(代码)

php中二维数组纵向合并&横向合并的代码实现

以上就是PHP如何封装打印日志的方法(附代码)的详细内容,更多请关注php中文网其它相关文章!

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。