php 文件日志类
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 文件日志类的更多相关文章
- 【等待事件】等待事件系列(3+4)--System IO(控制文件)+日志类等待
[等待事件]等待事件系列(3+4)--System IO(控制文件)+日志类等待 1 BLOG文档结构图 2 前言部分 2.1 导读和注意事项 各位技术爱好者,看完本文后,你可 ...
- [C#] 日志类
在程序发布到服务器上的时候,不能在像本地执行一样可以调试,在发生错误时候,往往不能很方便的查找错误.将错误信息写入文件是一种比较常用的处理方法.以下是一个日志类,实现以下功能: 1)按日期每天生产不同 ...
- android Loger日志类(获取内置sd卡)
Android手机自带内部存储路径的获取 原文地址:http://my.oschina.net/liucundong/blog/288183 直接贴代码: public static String g ...
- 【分享】我们用了不到200行代码实现的文件日志系统,极佳的IO性能和高并发支持,附压力测试数据
很多项目都配置了日志记录的功能,但是,却只有很少的项目组会经常去看日志.原因就是日志文件生成规则设置不合理,将严重的错误日志跟普通的错误日志混在一起,分析起来很麻烦. 其实,我们想要的一个日志系统核心 ...
- 自己编写的 C++ 超轻量级日志类
[自己编写的 C++ 超轻量级日志类(兼容vc++6.0.vs2010.vs2015)] 先来看效果: [测试文件:test.cpp] /* 作者:闫文山 时间:2017/07/02 介绍: 本日志类 ...
- C++ IO操作API及注意事项(包含一个日志类的实现)
C++是一个抽象程度比C高很多的语言,在使用C++时,编译器做了很多工作,如果我们不对C++的某些特性的实现机制进行了解,那么编程时也许会有很多疑惑,我们也许知道怎样做才是正确的,但不知道为什么要这样 ...
- python3 配置logging日志类
配置类config_file: from configparser import ConfigParser class config_file: def __init__(self,conf_file ...
- Python3自定义日志类教程
一.说明 Python3的logging功能是比较丰富的支持不同层次的日志输出,但或是我们想在日志前输出时间.或是我们想要将日志输入到文件,我们还是想要自定义日志类. 之前自己也尝试写过但感觉文档太乱 ...
- python3+selenium框架设计03-封装日志类
首先我们先来实现日志的功能,日志可以使用python3自带logging模块,不会的可以百度一下相关文章,也可以看我另外一篇文章Python3学习笔记24-logging模块 在封装日志类前,我们需要 ...
随机推荐
- MFC之进度条CProgressCtrl
一.成员函数简介 1.create()针对不是通过资源文件上拖拉进度条控件生成的进度条,需要用此函数创建一个. 2.SetRange()设置进度条的起始值和终止值. 3.SetPos()设置进度条的当 ...
- WindowsForm菜单工具栏--2016年12月6日
ContextMenuStrip 添加控件后可在其他空间属性中进行绑定 MenuStrip 设置热键:在编辑的时候输入(&F) 设置快捷键:选中菜单项--右键属性--S ...
- BZOJ 1923: [Sdoi2010]外星千足虫
Description 给出几个异或方程组求解,\(n \leqslant 2000\) Sol 高斯消元. 直接消元就行,遇到自由元就直接输出,同时记录一下用到的最高行数. 复杂度不科学就可以用 b ...
- angular自己最近学的一种筛选方法
投资状态vm.statusList = [ {name:"项目状态",value:-1}, {name:"上线",value:0}, {name:"投 ...
- css pre标签
浏览器:firfox49.0.2 在使用<pre>标签输出格式化文本的时候,遇到了一个小问题. 要在页面的底部输出两行文本,但是最后一行的文字总是距离屏幕的底部太大.下面图中的样子: 相关 ...
- 451. Sort Characters By Frequency
题目: Given a string, sort it in decreasing order based on the frequency of characters. Example 1: Inp ...
- C++ 基础知识复习(一)
数据类型,常量与变量部分:(发现有些点竟然这么多年第一次发现) C++基本数据类型有哪些: 答:整型,浮点型,void型. 注:其他各种数据类型均是这三种类型的扩充,另外void类型在实际程序中经常用 ...
- JavaOO面向对象中的注意点(二)
1.封装: 封装主要体现在:组装类 和 信息隐藏. a.信息隐藏:①访问修饰符:private ②方法的实现:get/set方法.run()方法-控制流程 b.组装类: ①类的定义:属性.构造.行为( ...
- winform对话框控件、打印控件
对话框控件: ColorDialog:颜色选择对话框,让用户自行选择一种颜色,使用方法类似FontDialog FontDialog:字体选择对话框,让用户自行选择一种字体(也可以选择字体颜色,需要在 ...
- js动态加载以及确定加载完成的代码
利用原生js动态加载js文件到页面,并在确定加载完成后调用相关function var otherJScipt = document.createElement("script") ...