由 PHP 处理 DST 的时区

2022-08-30 18:22:52

我正在处理日历应用程序。在此,来自不同时区的用户创建/查看事件。我正在考虑遵循以下方法,以节省UTC中的事件时间,并以用户的本地时间显示它们。注意:用户有他们的首选时区设置。

要将事件开始时间另存为 UTC 时间戳::

$timezone = new DateTimeZone( $user_timezone_name );
$utcOffset = $timezone->getOffset( new DateTime( $event_start_time_string_local ) );
$event_start_timestamp_local = maketime( $event_start_time_string_local );
//Now add/subtract $utcOffset to/from $event_start_timestamp_local to get event's start  //time  timestamp in UTC and save this result in DB.

要获取以用户时区为单位的事件开始时间,请执行以下操作:

date_default_timezone_set( $user_timezone_name );
$eventTimeLocalTime = date("Y-m-d H:i:s", $event_start_timestamp_in_UTC );

哪里:

user_timezone_name is user's timezone setting.
event_start_time_string_local is event's start time string in local/civil time.
event_start_timestamp_in_UTC is event's start time timestamp in UTC.

我的问题:

  • 上面使用的 PHP API 是否负责所有区域的 DST?
  • DST时间本身在不同年份发生变化,PHP如何获取有关此的信息?我们需要升级PHP吗?如果是这样,我们是否需要升级所有或特定的PHP库?

参考: - do-phps-date-default-timezone-set-adjust-to-daylight-saving - get-timezone-offset-for-a-given-location


答案 1

你太复杂了。要使用 在两个时区之间进行转换,请执行以下操作:DateTime

date_default_timezone_set('Asia/Kolkata'); // YOUR timezone, of the server

$date = new DateTime($input, new DateTimeZone('Asia/Tokyo')); // USER's timezone
$date->setTimezone(new DateTimeZone('UTC'));
echo $date->format('Y-m-d H:i:s');

这会从用户的本地时区转换为 UTC。若要反其道而行之,若要以用户的本地时间显示时间,请交换两个时区。

是的,PHP 负责 DST。必要的转换规则是 PHP 安装的一部分。您可以通过更新 PHP 或更新时区数据库来使它们保持最新状态。


答案 2

是的,php api 考虑了 DST。大多数时候,您可以安全地执行时间转换,就像dekeze所显示的那样。问题是,它并不总是可能的/可行的或有意义的。考虑以下示例 - 在波兰(2013年),10月27日凌晨3点,您的时钟向后移动一小时以切换到标准时间(偏移UTC + 01:00),3月31日凌晨2点时钟向前调整1小时以切换到夏令时(偏移UTC + 02:00)。现在让我们看看Grenwich / UTC中的“实时”滴答声,以及PHP从欧洲/华沙到UTC的转换是如何工作的:

Europe/Warsaw time   offset  UTC                    php2utc conversion   php offset
2013-10-27 01:00:00    +2    2013-10-26 23:00:00    2013-10-26 23:00:00  +2
2013-10-27 01:30:00    +2    2013-10-26 23:30:00    2013-10-26 23:30:00  +2
2013-10-27 02:00:00    +2    2013-10-27 00:00:00    2013-10-27 01:00:00  +1  *
2013-10-27 02:30:00    +2    2013-10-27 00:30:00    2013-10-27 01:30:00  +1  *
2013-10-27 02:59:00    +2    2013-10-27 00:59:00    2013-10-27 01:59:00  +1  *
     3am -> 2am .....................................summer time changes to standard(winter) time @3am we subtract 1h so 3am becomes 2am
2013-10-27 02:00:00    +1    2013-10-27 01:00:00    2013-10-27 01:00:00  +1
2013-10-27 02:30:00    +1    2013-10-27 01:30:00    2013-10-27 01:30:00  +1
2013-10-27 03:00:00    +1    2013-10-27 02:00:00    2013-10-27 02:00:00  +1  
2013-10-27 03:30:00    +1    2013-10-27 02:30:00    2013-10-27 02:30:00  +1  

正如你所看到的,在凌晨2点到凌晨3点之间,PHP无法知道“哪个”小时(从调整之前/之后),因此无法可靠地转换。希望这有助于某人的审议;-)


推荐