大家快瞧那结冰的湖水,春风一吹冰都融化了,河里的小鱼都游出海面,在湖水中自由的游来游去,多可爱的小鱼啊!多么欢快的小鱼啊!真是让人深深的为它那可爱的摸样着迷。春风一吹过那枯黄的小草身边时,小草突然边了摸样,它从原来的枯黄变成了嫩绿,慢慢地小草从嫩绿变成了鲜绿渐渐地越变越绿,绿的让人难以相信那是小草。啊!小草我为你的样子感到是个奇迹。
本文实例讲述了Yii框架实现记录日志到自定义文件的方法。分享给大家供大家参考,具体如下:
默认情况下,Yii::log($msg, $level, $category)
会把日志记录到runtime/application.log文件中
日志格式如下:
[时间] - [级别] - [类别] - [内容]
2013/05/03 17:33:08 [error] [application] test
但有时候需要把某些特定的日志放到特定的文件中,比如交易失败的日志,需要和其他日志区分开来单独记录。
在Yii中可以通过配置不同的CLogRouter来解决。
你需要先了解Yii的日志机制,Yii的日志功能有CLogger和CLogRouter两部分,
其中CLogger负责记录日志数据在内存中,而CLogRouter则决定如何处理这些日志数据,如记录到文件或数据库,或发送邮件等
其中的CFileLogRoute就是用来以文件的形式来处理日志数据的。那么很自然的,通过配置不同的CFileLogRoute就可以把日志记录到不同的日志文件中。
具体配置如下:
'log' => array( 'class' => 'CLogRouter', 'routes' => array( array( 'class' => 'CFileLogRoute', 'levels' => 'error, warning', ), array( 'class' => 'CFileLogRoute', 'levels' => 'error, warning', 'categories'=> 'orders.*', 'logFile'=> 'orders.log', ),
在需要记录订单错误的地方,添加如下代码:
Yii::log('your message', 'error', 'orders');
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。
到此这篇关于Yii框架实现记录日志到自定义文件的方法就介绍到这了。因为慈悲,所以容易知足;因为知足,所以容易快乐。更多相关Yii框架实现记录日志到自定义文件的方法内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!