0

0

log4php的配置及使用

炎欲天舞

炎欲天舞

发布时间:2017-08-04 10:17:09

|

3600人浏览过

|

来源于php中文网

原创

log4php的使用

首先引入logger.php文件。log4php可以通过引入logger.php来完成自动加载的过程。文件位置如下:

untitled.bmp

日志记录器自身没有定义日志的输出目的地和格式,所以我们通常需要引入log4php后要先引入配置文件(下面会详细介绍)。日志记录器是一个组件,我们通过日志记录器来记录日志信息。引入配置文件后通过getLogger获得一个将日志记录器实体。然后可以通过打印方法打印出日志信息。打印方法通常包括info、warn、error、debug等。

include('Logger.php');
Logger::Configure(COMMON_PATH . 'Conf/log.php');//引入配置文件
$logger = Logger::getLogger("main"); //生成日志实例
$logger->info("This is an informational message."); //在规定好的输出目的地用规定好的输出格式显示信息消息

log4php配置

log4php配置文件支持 XML、PHP、Properties (INI)等格式。同样支持可编程配置,即通过函数来改变配置。

class MyConfigurator implements LoggerConfigurator {
    
    public function configure(LoggerHierarchy $hierarchy, $input = null) {
 
        // Create an appender which logs to file
        $appFile = new LoggerAppenderFile('foo');
        $appFile->setFile('D:/Temp/log.txt');
        $appFile->setAppend(true);
        $appFile->setThreshold('all');
        $appFile->activateOptions();
        
        // Use a different layout for the next appender
        $layout = new LoggerLayoutPattern();
        $layout->setConversionPattern("%date %logger %msg%newline");
        $layout->activateOptions();
        
        // Create an appender which echoes log events, using a custom layout
        // and with the threshold set to INFO 
        $appEcho = new LoggerAppenderEcho('bar');
        $appEcho->setLayout($layout);
        $appEcho->setThreshold('info');
        $appEcho->activateOptions();
        // Add both appenders to the root logger
        $root = $hierarchy->getRootLogger();
        $root->addAppender($appFile);
        $root->addAppender($appEcho);
    }
}
        Logger::Configure(COMMON_PATH . 'Conf/log.php');

项目中由这行代码引入配置。配置中一般包含以下内容:

立即学习PHP免费学习笔记(深入)”;

1.日志信息的优先级;2.日志信息的输出目的地; 3.日志信息的输出格式。

一.log4php 日志信息优先级

日志信息的优先级从高到低有ERROR、WARN、INFO、DEBUG。

以下是常用四种等级的用法:DEBUG Level指出细粒度信息事件对调试应用程序是非常有帮助的。INFO level表明 消息在粗粒度级别上突出强调应用程序的运行过程。WARN level表明会出现潜在错误的情形。ERROR level指出虽然发生错误事件,但仍然不影响系统的继续运行。

程序只能显示比当前设置的等级优先级级更低的信息。例如当前程序设置level为DEBUG,那么就是说程序中所有信息都能显示出来。如果当前程序level为info,那么只有info,warn,error三中日志信息可以展示。

    return array(
    'rootLogger' => array(
        'appenders' => array(
            'myConsoleAppender',
        ),
        'level' => 'DEBUG'
    ),
    )

二.输出地址配置

和优先级一样,输出地址同样可以在配置文件中作出配置,并且可以根据不同的日志类别设置不同的输出目的地。例:

'loginFileAppender' => [
            'class' => 'LoggerAppenderDailyFile',
            'layout' => [
                'class' => 'LoggerLayoutPattern',
                'params' => [
                    'conversionPattern' => '%date [%logger] %message%newline',
                ],
            ],
            'params' => [
                'file' => './log/login/login_%s.log',
                'datePattern' => 'Y_m_d',
            ]
        ],

log4php支持12种输出目的地,分别为:

  • LoggerAppenderConsole 以php://stdout为输出目的地

  • LoggerAppenderFile 以文件为输出目的地

  • LoggerAppenderDailyFile 以文件为目的地,每日输出一个文件

  • LoggerAppenderDb 以数据库为输出目的地

  • LoggerAppenderEcho 在执行文件尾输出

  • LoggerAppenderMail 以邮件为输出地

  • LoggerAppenderMailEvent 以邮件为输出地, 为事件触发

  • LoggerAppenderNull 不输出任何信息

  • LoggerAppenderPhp LoggerAppenderPhp 输出至PHP错误信息,将各类日志等级信息转化为php标准信息

  • LoggerAppenderRollingFile 以xxx.log.1, xxx.log.2的形式输出

    Gnomic智能体平台
    Gnomic智能体平台

    国内首家无需魔法免费无限制使用的ChatGPT4.0,网站内设置了大量智能体供大家免费使用,还有五款语言大模型供大家免费使用~

    下载
  • LoggerAppenderSocket 以socket方式输出

  • LoggerAppenderSyslog 以系统日志为目的地输出,使用php中的syslog()函数进行记录

代码中便是规定了以每日输出一个文件作为输出目的地,用来记录登录类型的日志信息。

三.日志文件输出格式

它作为输出目的地的一个属性存在,log4php上包含5种不同的输出方式,分别为:

  • LoggerLayoutHtml 以html格式输出调试信息

  • LoggerLayoutSimple 简单的以 "等级信息 - 日志信息"的格式显示

  • LoggerLayoutTTCC 以"月/日/年 时间[进程] 等级信息 日志名称 - 调试信息"的格式来显示

  • LoggerLayoutPattern 以模式表达式作为输出格式来显示(这个模式可以自定义输出格式)

  • LoggerXmlLayout//以xml的模式来输出

LoggerLayoutPattern 模式的一些格式参数

LoggerLayoutPattern为我们提供了自定义日志信息格式的方法,项目中也常常使用该模式来自定义日志信息。在实际使用中,我们通过配置conversionPattern参数来定义模式。而参数变量中通常使用一些log4php提供的转换说明符来配置。
例如:

'conversionPattern' => '%date [%logger] %message%newline'

格式为: yyyy-mm-ddThh:mm:ss+08:00.[日志类型].日志内容.换行。

常用的转换说明符有:

  • %logger(%lo,%c)请求日志的日志记录器的名称。

  • %data($d)时间。默认为ISO8601格式。可以通过%data{(格式)}改变格式。

  • %location(%l)调用者的位置信息

  • %message(%m %msg)日志的内容

  • %n(%newline)换行

  • %level(%p)当前日志事件的优先级

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

php

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

51

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

397

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

118

2026.01.21

java版本选择建议
java版本选择建议

本专题整合了java版本相关合集,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

11

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9.1万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 9.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号