php 日志打印方法名,TP5日志打印方法封装

本文介绍了如何在ThinkPHP开发中通过添加静态方法实现日志记录,包括打印到控制台和指定文件,以及当文件过大时进行自动切割。方法涉及参数标记、内容写入和文件管理技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求:在开发及测试过程中需要打印日志,并且可以将日志内容打印到指定文件,这样方便查看。

过程:

1. 打开think\Log文件,在该文件中添加一个静态方法,代码如下:

/**

* @param $mark 备注

* @param $log_content 日志内容

* @param string $fname 文件名

*/

public static function mylog($mark, $log_content, $fname = "")

{

$max_size = 30000000; //字节

if ($fname == "") {

$log_filename = RUNTIME_PATH . '/log/' . date('Ym-d') . ".log";

} else {

$log_filename = RUNTIME_PATH . '/log/' . $fname . ".log";

}

if (file_exists($log_filename) && abs(filesize($log_filename)) > $max_size) {

//当日志文件过大,移动文件并重命名

rename($log_filename, dirname($log_filename) . DS . date('Ym-d-His') . $fname . ".log");

}

$t = microtime(true);

$micro = sprintf("%06d", ($t - floor($t)) * 1000000);

$d = new \DateTime (date('Y-m-d H:i:s.' . $micro, $t));

if(is_array($log_content)){

$log_content = JSONReturn($log_content);

}

file_put_contents($log_filename,

' ' . $d->format('Y-m-d H:i:s u') . " key:" . $mark . "\r\n" . $log_content . "\r\n------------------------ --------------------------\r\n",

FILE_APPEND);

}

2. 使用:

在控制器中引入Log类: use think\Log;

调用方法: Log::mylog("info:", JSONReturn($info), "admin_index");

3. 注意:JSONReturn()方法是放在了common.php文件中,代码如下:

function JSONReturn($result)

{

return json_encode($result,JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值