10

如果你不相信我,这里有一些我在 eclipse 中的调试表达式:

"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 时间吗?

谢谢!

4

5 回答 5

12

如果您想处理超出 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');
于 2010-07-16T14:57:40.850 回答
12

尝试在 2038 年 1 月 19 日星期二 03:14:07 UTC 之前保留它,届时 32 位系统的 unix 时间戳纪元将翻转!

它甚至在http://php.net/strtotime的手册中都有描述

编辑:刚刚测试:通过安装 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)
于 2010-07-16T14:50:43.970 回答
3

PHP 手册

时间戳的有效范围通常是从 1901 年 12 月 13 日星期五 20:45:54 GMT 到 2038 年 1 月 19 日星期二 03:14:07 GMT。(这些日期对应于 32 位有符号整数的最小值和最大值)。但是,在 PHP 5.1.0 之前,此范围在某些系统(例如 Windows)上被限制为 01-01-1970 到 19-01-2038。

另请参阅:2038 年问题 - 维基百科

于 2010-07-16T14:53:46.337 回答
2

您无法转换在 unix 时间翻转 (2038) 之后发生的日期

于 2010-07-16T14:53:41.353 回答
1

简单替换strtotime

$date = '2199-12-31T08:00:00.000-06:00';

echo date('Y-m-d', strtotime($date)); // fails with 1970 result

echo date_format(  date_create($date) , 'Y-m-d'); // works perfect with 5.2+

实际帖子在这里

于 2015-04-24T04:08:24.380 回答