这是我的函数:
现在我正在获取Nginx日志:
public static function GetFormattedMicroTime($timestamp = false) {
if(!$timestamp)
$timestamp = microtime(true);
return DateTime::createFromFormat('U.u',sprintf('%.f', $timestamp))->format('Y-m-d\TH:i:s.u');
}
这是我如何调用它(我只从我的代码中的一个点调用它):
$microtime = microtime(true);
$sinceLastLog = number_format($microtime - self::$lastLogTime,4);
self::$lastLogTime = $microtime;
return Utils::GetFormattedMicroTime($microtime) .'|'. $sinceLastLog .'| blah blah';
我遇到了很多这样的错误:
PHP信息:PHP致命错误:调用非对象成员函数format()
有人能帮我排除故障吗?
编辑:
我正在使用php-fpm 5.4.28
我已经稍微更改了我的函数:
public static function GetFormattedMicroTime($timestamp = false) {
if(!$timestamp)
$timestamp = microtime(true);
$d = DateTime::createFromFormat('U.u',sprintf('%.f', $timestamp));
if ($d instanceof DateTime){
return $d->format('Y-m-d\TH:i:s.u');
} else {
error_log("Erreur date ! timestamp = $timestamp erreur =".print_r(DateTime::getLastErrors(),true));
return $timestamp;
}
}
现在我正在获取Nginx日志:
PHP message: Erreur date ! timestamp = 1403539343,372 erreur = Array
(
[warning_count] => 0
[warnings] => Array
(
)
[error_count] => 2
[errors] => Array
(
[10] => Unexpected data found.
)
)
format('Y-m-d\TH:i:s.u')
来设置一个制表符,请使用\t
或\\t
。 - Funk Forty NinerDateTime::createFromFormat('U.u','1403538707.536290')
在版本 5.3.0 及以下无法工作。不过我不知道为什么会这样。 - Jim