4

如何更改 Zend_Log 的日期格式?

现在每个新日志条目前面都添加了带有时间戳的日期:
“2013-01-28T16:47:54+01:00 ... some log message ...”

但我想将此日期格式化为:
“Ymd H:i:s ... some log message ...”

我的代码如下所示:

class Game_Logger {

    public function __construct($val, $txt = null) {
        $writer = new Zend_Log_Writer_Stream(APPLICATION_PATH . '/../log/log.log');
        $logger = new Zend_Log($writer);
        if (is_array($val)) {
            $output = Zend_Debug::dump($val, null, false);
        } else {
            $output = $val;
        }
        if($txt){
            $output = $txt.' '.$output;
        }
        $logger->info($output);
    }

}
4

2 回答 2

6

可能这将解决您的问题:

$logger->setTimestampFormat("H:i:s");
但有些事情告诉我你已经想通了;)。

于 2013-02-25T16:07:02.520 回答
1

对于 Zend Framework 2 和 3,下面的代码可能会有所帮助

    $logger = new \Zend\Log\Logger();

    $formatter = new  \Zend\Log\Formatter\Simple();
    $formatter->setDateTimeFormat('Y-m-d'); // as per your choice

    $writer = new \Zend\Log\Writer\Stream('php://output');
    $writer->setFormatter($formatter);
    $logger->addWriter($writer);
于 2019-02-14T08:25:45.080 回答