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

2038年1月19日火曜日03:14:07UTCの前に、32ビットシステムのUNIXタイムスタンプエポックがロールオーバーする前に保持してください。

http://php.net/strtotimeのマニュアルにも記載されています

編集:テスト済み:64ビットOSと適切な64ビットバージョンのphpをインストールすることで修正されました。生まれ変わった2000年問題を修正するのに十分な時間があると思います。

$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 に答える
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 に答える
3

PHPマニュアルから:

タイムスタンプの有効な範囲は、通常、1901年12月13日金曜日20:45:54GMTから2038年1月19日火曜日03:14:07GMTまでです。(これらは、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 に答える