mysql — функция времени php работает, затем перестает работать

Так что я нашел этот код по ссылке ниже, и он работал нормально, как 2 дня назад, но потом просто перестает работать. когда я дал ему время из mysql CURRENT TIMESTAMP, он просто выводит 8, 7 или 6 часов, независимо от того, сколько времени прошло. если кто-нибудь знает, как улучшить этот или лучший способ сделать функцию, пожалуйста, отправьте ее здесь или дайте мне ссылку на нее. Я пробовал это на php 5.6 и php 7, но ни исправить это.

пример:

$ time = 2017-09-11 17:10:51

вход:

time_elapsed_string ($ время);

выход:

5 часов назад

#function from https://stackoverflow.com/questions/1416697/converting-timestamp-to-time-ago-in-php-e-g-1-day-ago-2-days-ago
function time_elapsed_string($datetime, $full = false) {
$now = new DateTime;
$ago = new DateTime($datetime);
$diff = $now->diff($ago);

$diff->w = floor($diff->d / 7);
$diff->d -= $diff->w * 7;

$string = array(
'y' => 'year',
'm' => 'month',
'w' => 'week',
'd' => 'day',
'h' => 'hour',
'i' => 'minute',
's' => 'second',
);
foreach ($string as $k => &$v) {
if ($diff->$k) {
$v = $diff->$k . ' ' . $v . ($diff->$k > 1 ? 's' : '');
} else {
unset($string[$k]);
}
}

if (!$full) $string = array_slice($string, 0, 1);
return $string ? implode(', ', $string) . ' ago' : 'just now';
}

-3

Решение

когда я дал ему время из mysql CURRENT TIMESTAMP, он просто выводит 8, 7 или 6 часов, независимо от того, сколько времени прошло

Похоже, ваш сервер MySQL и сервер PHP работают в разных часовых поясах.

Приведенный вами пример кода не учитывает часовые пояса, а просто вычисляет разницу между местным временем между указанной датой и текущим временем.

Для учета разных часовых поясов вы можете использовать DateTime::setTimezone: http://php.net/manual/en/datetime.settimezone.php

Пример:

$date = new DateTime('2000-01-01', new DateTimeZone('Pacific/Nauru'));
echo $date->format('Y-m-d H:i:sP') . "\n"; // 2000-01-01 00:00:00+12:00

$date->setTimezone(new DateTimeZone('Pacific/Chatham'));
echo $date->format('Y-m-d H:i:sP') . "\n"; // 2000-01-01 01:45:00+13:45
0

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector