PHP 和 DST 转换问题

PHP and DST conversion issue

我无法理解我的代码如何适应 DST,因为最近的更新不正确。我将基于 UTC 的日期时间存储在数据库中,然后将其转换回本地时区以供显示。如果 PHP 考虑了夏令时,则有其他问题,因为我所有存储的日期都延迟了 1 小时。

$stored_date = '2016-11-16 12:04:01'; // in UTC

$dateTime = new DateTime($stored_date, new DateTimeZone('UTC'));
$dateTimeZone = new DateTimeZone('America/New_York');
$dateTime->setTimezone($dateTimeZone);

print_r($dateTime);

上周,在 DST 结束之前,这将打印出 2016-11-16 08:04:01。本周,既然 DST 已经结束,它会打印出 2016-11-16 07:04:01。如果 PHP 正确处理 DST 转换,为什么会有时差?

服务器设置应该无关紧要(我不认为),因为我明确地在 PHP 内进行转换,对吗?

我准备开始使用 PHP 检查 DST 是否生效并将转换偏移 1 小时,因为我不明白为什么那个小时没有自动补偿在 DateTime class.

纽约市在这些时区之间切换:

  • 冬季:EST(东部标准时间)= UTC -5
  • 夏季:EDT(东部夏令时)= UTC -4

根据 timeanddate.com,转换将在 11 月 6 日进行。因此结果是正确的:12 - 5 = 7

换句话说,PHP 完全了解 DST,正如我们在以下代码中看到的那样:

$dateTime = new DateTime('2016-11-05 12:04:01', new DateTimeZone('UTC'));
$dateTime->setTimezone(new DateTimeZone('America/New_York'));
echo $dateTime->format('r') . PHP_EOL;

$dateTime = new DateTime('2016-11-06 12:04:01', new DateTimeZone('UTC'));
$dateTime->setTimezone(new DateTimeZone('America/New_York'));
echo $dateTime->format('r') . PHP_EOL;
Sat, 05 Nov 2016 08:04:01 -0400
Sun, 06 Nov 2016 07:04:01 -0500

您可以检查系统时间数据库中可用的准确信息:

$timeZone = new DateTimeZone('America/New_York');
print_r($timeZone->getTransitions(mktime(0, 0, 0, 1, 1, 2016), mktime(0, 0, 0, 12, 31, 2016)));
Array
(
    [0] => Array
        (
            [ts] => 1451602800
            [time] => 2015-12-31T23:00:00+0000
            [offset] => -18000
            [isdst] => 
            [abbr] => EST
        )

    [1] => Array
        (
            [ts] => 1457852400
            [time] => 2016-03-13T07:00:00+0000
            [offset] => -14400
            [isdst] => 1
            [abbr] => EDT
        )

    [2] => Array
        (
            [ts] => 1478412000
            [time] => 2016-11-06T06:00:00+0000
            [offset] => -18000
            [isdst] => 
            [abbr] => EST
        )

)