简体   繁体   中英

Write a header to a log with log4php

I have semi-colon separated values logged to a csv file using log4php. I wanted to write a header in first line. How this can be done?

Example

message id, file name, start time, end time, status MSGID1000;SAMPLE.TXT;01:05:55;07:08:44;OK MSGID1000;SAMPLE.TXT;01:05:55;07:08:44;NOK

I do this

csvLogger = Logger::getRootLogger();
csvLogger->setLevel(LoggerLevel::toLevel(LoggerLevel::DEBUG));
csvLogger->removeAllAppenders();

$appender = new LoggerAppenderFile("csvLogAppender");
$appender->setFile("LogMessage.csv");
$appender->setAppend(false);   

csvLogger->addAppender($appender); 

I found solution to extend LoggerLayoutPattern and override the getHeader() method.

class csvLoggerLayoutPattern extends LoggerLayoutPattern {
    public function getHeader() {
        return "message id, file name, start time, end time, status\n";
    }
}

csvLogger = Logger::getRootLogger();
csvLogger->setLevel(LoggerLevel::toLevel(LoggerLevel::DEBUG));
csvLogger->removeAllAppenders();

$appender = new LoggerAppenderFile("csvLogAppender");
$appender->setFile("LogMessage.csv");
$appender->setAppend(false);

$appenderlayout = new csvLoggerLayoutPattern();
$appenderlayout->activateOptions();
$appender->setLayout($appenderlayout);

csvLogger->addAppender($appender);

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM