好得很程序员自学网
  • 首页
  • 后端语言
    • C#
    • PHP
    • Python
    • java
    • Golang
    • ASP.NET
  • 前端开发
    • Angular
    • react框架
    • LayUi开发
    • javascript
    • HTML与HTML5
    • CSS与CSS3
    • jQuery
    • Bootstrap
    • NodeJS
    • Vue与小程序技术
    • Photoshop
  • 数据库技术
    • MSSQL
    • MYSQL
    • Redis
    • MongoDB
    • Oracle
    • PostgreSQL
    • Sqlite
    • 数据库基础
    • 数据库排错
  • CMS系统
    • HDHCMS
    • WordPress
    • Dedecms
    • PhpCms
    • 帝国CMS
    • ThinkPHP
    • Discuz
    • ZBlog
    • ECSHOP
  • 高手进阶
    • Android技术
    • 正则表达式
    • 数据结构与算法
  • 系统运维
    • Windows
    • apache
    • 服务器排错
    • 网站安全
    • nginx
    • linux系统
    • MacOS
  • 学习教程
    • 前端脚本教程
    • HTML与CSS 教程
    • 脚本语言教程
    • 数据库教程
    • 应用系统教程
  • 新技术
  • 编程导航
    • 区块链
    • IT资讯
    • 设计灵感
    • 建站资源
    • 开发团队
    • 程序社区
    • 图标图库
    • 图形动效
    • IDE环境
    • 在线工具
    • 调试测试
    • Node开发
    • 游戏框架
    • CSS库
    • Jquery插件
    • Js插件
    • Web框架
    • 移动端框架
    • 模块管理
    • 开发社区
    • 在线课堂
    • 框架类库
    • 项目托管
    • 云服务

当前位置:首页>后端语言>PHP
<tfoot draggable='sEl'></tfoot>

phplog日志类 phpstudy日志

很多站长朋友们都不太清楚phplog日志类,今天小编就来给大家整理phplog日志类,希望对各位有所帮助,具体内容如下:

本文目录一览: 1、 php实现的debug log日志操作类实例 2、 php该在哪里写日志?怎么写日志?日志是做什么用的? 3、 怎么让php打印错误日志? 4、 php实现日志管理(记录用户操作)原理 5、 如何开启PHP日志功能? php实现的debug log日志操作类实例

本文实例讲述了php实现的debug

log日志操作类。分享给大家供大家参考,具体如下:

<?php

class

Tool

{

public

static

function

log($info)

{

$time

=

date('m-d

H:i:s');

$backtrace

=

debug_backtrace();

$backtrace_line

=

array_shift($backtrace);

//

哪一行调用的log方法

$backtrace_call

=

array_shift($backtrace);

//

谁调用的log方法

$file

=

substr($backtrace_line['file'],

strlen($_SERVER['DOCUMENT_ROOT']));

$line

=

$backtrace_line['line'];

$class

=

isset($backtrace_call['class'])

?

$backtrace_call['class']

:

'';

$type

=

isset($backtrace_call['type'])

?

$backtrace_call['type']

:

'';

$func

=

$backtrace_call['function'];

file_put_contents($_SERVER['DOCUMENT_ROOT'].'/debug.log',

"$time

$file:$line

$class$type$func:

$info\n",

FILE_APPEND);

}

}

class

Action

{

public

function

a()

{

$this->b();

}

public

function

b()

{

$this->c();

}

public

function

c()

{

Tool::log('sdfsdf');

}

}

$action

=

new

Action();

$action->a();

这里再补充一个函数:

function

loginfo($format)

{

$args

=

func_get_args();

array_shift($args);

$d

=

debug_backtrace(DEBUG_BACKTRACE_PROVIDE_OBJECT,

1)[0];

$info

=

vsprintf($format,

$args);

$data

=

sprintf("%s

%s,%d:

%s\n",

date("Ymd

His"),

$d["file"],

$d["line"],

$info);

file_put_contents(__DIR__."/log.txt",

$data,

FILE_APPEND);

}

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP错误与异常处理方法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP运算与运算符用法总结》、《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家PHP程序设计有所帮助。

php该在哪里写日志?怎么写日志?日志是做什么用的?

所谓的日志就是记录系统运行状态的数据。

一般是将信息记录到文本文件或数据库中。

比如:

<?php

function writeLog($msg){

$logFile = date('Y-m-d').'.txt';

$msg = date('Y-m-d H:i:s').' >>> '.$msg."\r\n";

file_put_contents($logFile,$msg,FILE_APPEND );

}

//调用上面的函数,写一条信息进日志文件

writeLog('这是测试日志信息');

?>

怎么让php打印错误日志?

(1)使用echo ,简单输出

(2)使用print_r(),可以有规则的打印复杂结构

(3)var_dump递归输出某种结构体

(4)print(),简单打印

可以将你要输出的错误内容放到上述语句或函数内进行打印输出;也可以写入某个文件,作为你的Log日志:file_put_contents('/test1.txt',$value['value'],FILE_APPEND)等这类文件函数

以上是我自己工作中总结的PHP调试方法,挺好用的。

php实现日志管理(记录用户操作)原理

把日志需要保留的数据用json串或xml等数据结构的方式存储起来,调用的时候直接解析这些数据结构即可。

按简单的理解,给各模块的关键步骤起个操作名字,记录一下该操作名,时间,用户,IP等就完了。

单入口模式,这样只需要往index.php加入write_log功能就好了。

至于哪个字段,原值,新值,这个没什么好方法啊,可以引入插件机制,

开个类存储插件方法,命名以module_task为准,比如以上的url就是article_update

那么这个插件类就是

class plugin

{

public $extraLog;

function article_update($field,$old,$new)

{

self::$extraLog = array('字段'=>$field,'原值'=>$old,'新值'=>$new);

}

}

这个方法在流程页面进行数据库操作的地方调用,index.php的write_log流程只读plubin::$extraLog,循环然后和其它信息一起入库或文件。

如何开启PHP日志功能?

在php编程中,对于一些访问没有明显错误提示的php页面,可以通过error_log来做进一步的判定。

但出于种种原因,有些服务器并没有开启PHP的error_log功能。

测试或其它需要时,可以打开一下,方法如下。

编辑php.ini,将log_errors设置为on:

log_errors = On

然后,重启apache即可。

如成功开启,就可以跟踪到对应的错误提示:

[Mon Sep 24 16:57:01 2012] [error] [client 218.5.80.210] PHP Warning: fsockopen() has been disabled for security reasons in /home/bccgi-bin/fsockopen.php on line 2

[Mon Sep 24 16:57:02 2012] [error] [client 218.5.80.210] PHP Warning: fsockopen() has been disabled for security reasons in /home/bccgi-bin/fsockopen.php on line 2

[Mon Sep 24 16:57:03 2012] [error] [client 218.5.80.210] PHP Warning: fsockopen() has been disabled for security reasons in /home/bccgi-bin/fsockopen.php on line 2

[Mon Sep 24 16:57:04 2012] [error] [client 218.5.80.210] PHP Warning: fsockopen() has been disabled for security reasons in /home/bccgi-bin/fsockopen.php on line

另外,注意在Windows环境下,除了将log_errors设置为on外,还需要定义error_log的路径及文件名:

error_log = d:/temp/error.log

(此目录需要授予php标识用户的修改权限,否则日志文件无法生成)

IIS没有error_log的概念,所以需要另外定义。

关于phplog日志类的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。

查看更多关于phplog日志类 phpstudy日志的详细内容...

声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did208461
更新时间:2023-05-03   阅读:39次

上一篇: 手机下载的php 手机下载的app隐藏了怎么找出来

下一篇:php语言基础语法讲解 php语法总结

最新资料更新

  • 1.phpajix的简单介绍
  • 2.php加密解密 php数据加密解密
  • 3.php课堂系统 php网课系统
  • 4.关于winformphp的信息
  • 5.php获取js变量 php获取js变量值
  • 6.php类方法 php类方法访问变量
  • 7.php+rpush的简单介绍
  • 8.php物业台账公式 物业台账是什么意思
  • 9.php网页滚动代码 php 如何做滑动加载
  • 10.notepad写php notepad可以写c语言吗
  • 11.php每天更新数据 php数据库更新语句
  • 12.nginx隐藏.php nginx隐藏ip
  • 13.qbapi.php的简单介绍
  • 14.php网站设计素材 php网站制作
  • 15.php中table行宽 php网页表格
  • 16.接口的继承php 接口的继承和实现
  • 17.php学费多少兄弟连 php教程兄弟连
  • 18.php下载表格 php下载功能
  • 19.php显示字段内容 php限制显示字数
  • 20.php怎么操作树 php tree

CopyRight:2016-{hedonghua:year}{hedonghua:sitegs} 备案ICP:湘ICP备09009000号-16 {hedonghua:sitejym}
本站资讯不构成任何建议,仅限于个人分享,参考须谨慎!
本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。
本网站刊载的所有内容(包括但不仅限文字、图片、LOGO、音频、视频、软件、程序等)版权归原作者所有。任何单位或个人认为本网站中的内容可能涉嫌侵犯其知识产权或存在不实内容时,请及时通知本站,予以删除。

网站内容来源于网络分享,如有侵权发邮箱到:kenbest@126.com,收到邮件我们会即时下线处理。
网站框架支持:HDHCMS   51LA统计 百度统计
Copyright © 2018-2025 「好得很程序员自学网」
[ SiteMap ]