1

基本上我的网站是全球性的,我需要能够检测用户的时区并显示准确的时间。我有这个非常简洁的脚本,它曾经完美地工作到现在。它需要一个时区偏移量,我使用 javascript 获取并通过 cookie 传递。

if(!empty($_COOKIE['tz']) && $_COOKIE['tz']>=-12 && $_COOKIE['tz']<=13){
    $offset = $_COOKIE['tz'];
    $tz = timezone_name_from_abbr(null, $offset * 3600, true);
    if($tz === false) $tz = timezone_name_from_abbr(null, $offset * 3600, false);
    date_default_timezone_set($tz);
}else{
    date_default_timezone_set('UTC');
}

问题是目前我正在测试的时区是欧洲/赫尔辛基,它是 UTC+2(没有夏令时),但由于某种原因timezone_name_from_abbr()决定 2*3600 是欧洲/巴黎。我的日期和时区真的很糟糕,我非常需要帮助,拜托!

4

1 回答 1

5

通常,仅基于偏移量(例如 UTC+02:00)定位准确时区(例如Europe/HelsinkiEurope/Paris)的想法在任何可靠性或准确性方面都是不可能的。许多时区在任何给定时间点共享相同的偏移量,并且由于夏令时规则,许多时区全年在两个不同的偏移量之间切换。

您可以在此处查看所有时区及其标准和日光偏移的列表。

即使从时区缩写变为时区的想法也不合理,因为多个时区可以共享相同的缩写。例如,“CST”可以是“Central Standard Time”(美国)、“Central Standard Time”(澳大利亚)、“Central Summer Time”(澳大利亚)、“China Standard Time”或“Cuba Standard Time”。有关详细信息,请参阅此列表

考虑到这些问题,PHP 会为您提供一个名为timezone_name_from_abbr. 我建议避免使用它,因为它在概念上显然存在缺陷。

如果您要检测用户的时区,请考虑使用 JavaScript 库jsTimeZoneDetect。它也不是完美的,但它通常可以工作,并且基于更合乎逻辑的算法。

于 2013-10-27T22:19:51.363 回答