PHP: strtotime возвращает false для будущей даты?

вот некоторые выражения отладки, которые я поместил в затмение, если Вы не верите мне:

"strtotime("2110-07-16 10:07:47")" = (boolean) false    
"strtotime("2110-07-16")" = (boolean) false 

я использую его в своей функции, которая возвращает случайную дату между запуском и даты окончания:

public static function randomDate($start_date, $end_date, $format = DateTimeHelper::DATE_FORMAT_SQL_DATE)
    {
        if($start_date instanceof DateTime)     $start_date = $start_date->format(DateTimeHelper::DATE_FORMAT_YMDHMS);
        if($end_date instanceof DateTime)       $end_date   = $end_date->format(DateTimeHelper::DATE_FORMAT_YMDHMS);

        // Convert timetamps to millis
        $min = strtotime($start_date);
        $max = strtotime($end_date);

        // Generate random number using above bounds
        $val = rand($min, $max);

        // Convert back to desired date format
        return date($format, $val);
    }

какая-либо идея, как заставить это возвращать правильное время Unix для будущей даты?

спасибо!

9
задан Garrett 16 July 2010 в 14:49
поделиться

4 ответа

Если вы хотите работать с датами, выходящими за пределы 32-битного целочисленного диапазона дат, используйте объекты PHP dateTime

try {
    $date = new DateTime('2110-07-16 10:07:47');
} catch (Exception $e) {
    echo $e->getMessage();
    exit(1);
}

echo $date->format('Y-m-d');
12
ответ дан 4 December 2019 в 07:22
поделиться

Из руководства по PHP:

Действительный диапазон временной метки обычно составляет от Fri, 13 Dec 1901 20:45:54 GMT до Tue, 19 Jan 2038 03:14:07 GMT. (Это даты, которые соответствуют минимальному и максимальному значениям для 32-битного знакового целого числа). Однако до версии PHP 5.1.0 этот диапазон был ограничен от 01-01-1970 до 19-01-2038 в некоторых системах (например, Windows).

См. также: Проблема 2038 года - Википедия

3
ответ дан 4 December 2019 в 07:22
поделиться

Вы не можете конвертировать даты, которые происходят после переноса времени unix (2038)

2
ответ дан 4 December 2019 в 07:22
поделиться

Постарайтесь сохранить его до вторника, 19 января 2038 г., 03:14:07 UTC, когда эпоха временных меток unix для 32-битных систем перевернется!

Это даже описано в руководстве по адресу http://php.net/strtotime

edit: Только что протестировано: это исправлено установкой 64-битной ОС и соответствующей 64-битной версии php. Думаю, у нас есть достаточно времени, чтобы исправить ошибку перевоплощенного тысячелетия:

$one = strtotime("9999-12-31 23:59:59");  
$two = strtotime("10000-01-01 00:00:00");
var_dump($one);
var_dump($two);

int(253402297199)
bool(false)
12
ответ дан 4 December 2019 в 07:22
поделиться
Другие вопросы по тегам:

Похожие вопросы: