php文件日志类,按年月日组织目录结构。

<?php

class FileLog
{
private $_filepath; //文件路径
private $_filename; //日志文件名
private $_filehandle; //文件句柄 function __construct($fileName = 'log')
{
date_default_timezone_set('PRC');
$this->_filename = $fileName;
$this->init();
} /*
* 构造函数调用,初始化文件保存路径,文件名
*/
function init()
{
//如果有定义LOG_PATH常量,日志记录在LOG_PATH下,如果没有定义记录在当前目录 的logs
$this->_filepath = defined('LOG_PATH') ? LOG_PATH : './logs';
$this->_filepath = rtrim($this->_filepath, '/');
$this->_filepath .= '/' . date('y', time()) . '/' . date('m', time());
if (!is_dir($this->_filepath)) {
mkdir($this->_filepath, 0777, true);
}
if (!is_dir($this->_filepath)) {
//如果目录创建失败直接返回
$this->_filehandle = null;
return;
}
//拼接完整的文件名
$pathinfo = pathinfo($this->_filename);
$extension = isset($pathinfo['extension']) ? $pathinfo['extension'] : '';//取文件的扩展名
$this->_filename = $this->_filepath . '/' . $pathinfo['filename'] . '_' . date('d', time());
$this->_filename .= empty($extension) ? '.log' : '.' . $extension;
//打开文件
$this->_filehandle = fopen($this->_filename, "a+");
} /**
*作用:初始化记录类,写入记录
*输入:要写入的记录,可以是数组
*输出:写入成功返回true失败返回false
*/
public function addLog($log)
{
if (empty($this->_filehandle))
return false;
$strLog = '';
$strLog .= date("Y-m-d H:i:s") . ' ' . $this->_getUrl() . "\r\n";
$strLog .= "POST: " . $this->_postData() . "\r\n";
if (is_array($log)) {
$strLog .= $this->array2string($log);
} else {
$strLog .= $log . "\r\n";
}
$strLog .= "\r\n"; //写日志
fwrite($this->_filehandle, $strLog) !== false;
} function array2string($data)
{
$log_a = "";
foreach ($data as $key => $value) {
if (is_array($value)) $log_a .= "[" . $key . "] => (" . $this->array2string($value) . ") \r\n";
else $log_a .= "[" . $key . "] => " . $value . "\r\n";
}
return $log_a;
} /**
*作用:获取完整URL路径
*输入:完整URL路径
*输出:URL路径字串
*/
private function _getUrl()
{
$host = isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : (isset($_SERVER['SERVER_NAME']) ? $_SERVER['SERVER_NAME'] : 'localhost');
return 'http' . (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on' ? 's' : '')
. '://'
. $host
. $_SERVER['REQUEST_URI'];
} /**
*作用:获取POST数据
*输入:POST数据
*输出:POST数组
*/
private function _postData()
{
$strPost = '';
if (isset($_POST) && count($_POST) > 0) {
foreach ($_POST as $key => $val) {
$strPost .= $key . '=' . $val . '&';
}
}
$strPost=trim($strPost,'&');
return $strPost;
} /**
*功能: 析构函数,释放文件句柄
*输入: 无
*输出: 无
*/
function __destruct()
{
//关闭文件
if (!empty($this->_filehandle))
fclose($this->_filehandle);
}
} ?>

php 文件日志类的更多相关文章

  1. 【等待事件】等待事件系列(3+4)--System IO(控制文件)+日志类等待

     [等待事件]等待事件系列(3+4)--System IO(控制文件)+日志类等待   1  BLOG文档结构图     2  前言部分   2.1  导读和注意事项 各位技术爱好者,看完本文后,你可 ...

  2. [C#] 日志类

    在程序发布到服务器上的时候,不能在像本地执行一样可以调试,在发生错误时候,往往不能很方便的查找错误.将错误信息写入文件是一种比较常用的处理方法.以下是一个日志类,实现以下功能: 1)按日期每天生产不同 ...

  3. android Loger日志类(获取内置sd卡)

    Android手机自带内部存储路径的获取 原文地址:http://my.oschina.net/liucundong/blog/288183 直接贴代码: public static String g ...

  4. 【分享】我们用了不到200行代码实现的文件日志系统,极佳的IO性能和高并发支持,附压力测试数据

    很多项目都配置了日志记录的功能,但是,却只有很少的项目组会经常去看日志.原因就是日志文件生成规则设置不合理,将严重的错误日志跟普通的错误日志混在一起,分析起来很麻烦. 其实,我们想要的一个日志系统核心 ...

  5. 自己编写的 C++ 超轻量级日志类

    [自己编写的 C++ 超轻量级日志类(兼容vc++6.0.vs2010.vs2015)] 先来看效果: [测试文件:test.cpp] /* 作者:闫文山 时间:2017/07/02 介绍: 本日志类 ...

  6. C++ IO操作API及注意事项(包含一个日志类的实现)

    C++是一个抽象程度比C高很多的语言,在使用C++时,编译器做了很多工作,如果我们不对C++的某些特性的实现机制进行了解,那么编程时也许会有很多疑惑,我们也许知道怎样做才是正确的,但不知道为什么要这样 ...

  7. python3 配置logging日志类

    配置类config_file: from configparser import ConfigParser class config_file: def __init__(self,conf_file ...

  8. Python3自定义日志类教程

    一.说明 Python3的logging功能是比较丰富的支持不同层次的日志输出,但或是我们想在日志前输出时间.或是我们想要将日志输入到文件,我们还是想要自定义日志类. 之前自己也尝试写过但感觉文档太乱 ...

  9. python3+selenium框架设计03-封装日志类

    首先我们先来实现日志的功能,日志可以使用python3自带logging模块,不会的可以百度一下相关文章,也可以看我另外一篇文章Python3学习笔记24-logging模块 在封装日志类前,我们需要 ...

随机推荐

  1. php引用

    1.需求 了解php引用 2.变量的引用 目前为止看到的引用是变量的引用, 例子1 $a="ABC"; $b =&$a; echo $a;//这里输出:ABC echo $ ...

  2. T-SQL 语句的优化

    SQL调优. 1.索引是数据库调优的最根本的优化方法.聚簇索引.非聚簇索引. 聚簇索引:物理序与索引顺序相同.(只能有一个) 非聚簇索引:物理顺序与索引顺序不相同. 2.调整WHERE 子句中的连接顺 ...

  3. runtime的黑魔法

    要说明runtime,首先要明白objc这门语言,是基于C的封装.真是因为runtime,objc才有了面对对象的特性. 也就说,所有objc的语言,在运行时都会转换成C. 也是基于这样的特性,run ...

  4. Java Swing

    参考帖子http://chenchaobox.blog.163.com/blog/static/6043759020127845945569/ http://wenku.baidu.com/link? ...

  5. poj 3687(拓扑排序)

    http://poj.org/problem?id=3687 题意:有一些球他们都有各自的重量,而且每个球的重量都不相同,现在,要给这些球贴标签.如果这些球没有限定条件说是哪个比哪个轻的话,那么默认的 ...

  6. linuxqq

    centos7下安装linuxqq出现一大堆依赖包都没有,腾讯搞的这个产品真不给力.寒心. >>>以下来自百度知道:http://zhidao.baidu.com/question/ ...

  7. .NET LINQ 投影运算

    投影运算      投影是指将对象转换为一种新形式的操作,该形式通常只包含那些将随后使用的属性. 通过使用投影,您可以构建依据每个对象生成的新类型. 您可以映射属性,并对该属性执行数学函数. 还可以在 ...

  8. iOS 运行时

    1.点击每一个cell都要跳转到一个控制器,swich会很麻烦,那么可以用运行时来进行跳转. a. 定义一个数组用来存放控制器的名字 - (NSArray *)controllerArr{ if (_ ...

  9. VR技术的高速发展阶段

    转载请声明转载地址:http://www.cnblogs.com/Rodolfo/,违者必究. 在虚拟现实技术的高速发展阶段,与虚拟现实密切相关的计算机图形学.数字图像处理.传感技术等学科迅速发展,从 ...

  10. phpcms调用一个指定的栏目的url和栏目名称

    {$CATEGORY[$catid]['url']} 指定栏目URL代码 {$CATEGORY[$catid]['catname']} 指定栏目名称代码 {$CATEGORYS[41]['url']} ...