1

此脚本返回不一致的天数。在本地主机返回 14 天,在客户端服务器返回 15 天。

    $_POST['pickup_time'] = '13:30';
    $_POST['dropoff_time'] = '12:00';
    $_POST['pickup_date'] = '2013-10-16';
    $_POST['dropoff_date'] = '2013-10-30';


    $fmt_pickup_date = strtotime($_POST['pickup_date']);
    $fmt_dropoff_date = strtotime($_POST['dropoff_date']);

    $days = ceil(abs($fmt_dropoff_date - $fmt_pickup_date) / 86400);

    if ($vehicles[$v]['vehicle_cal_date']==0)
    {
        $fmt_pickup_time = str_replace(":", "", $_POST['pickup_time']);
        $fmt_dropoff_time = str_replace(":", "", $_POST['dropoff_time']);

        if (($fmt_dropoff_time-$fmt_pickup_time)>=1)
        {
            $days++;
        }
    }
    else { $days++; }

对于某些日期返回正确的天数,而对于某些错误(+1 天)。

    [pickup_time] => 11:00
    [dropoff_time] => 10:00
    [pickup_date] => 2013-10-28
    [dropoff_date] => 2013-11-01

这些日期在两台服务器上返回 4 天,这是正确的。

有任何想法吗?怎么了?

编辑:

这似乎是:

    date_default_timezone_set('UTC');

修复了问题,现在脚本返回两个日期的正确天数。多久——不知道。我希望这将在所有日期修复它:)

4

3 回答 3

2

这个问题真的很简单,这是我长期以来一直在重复的问题......当然,如果您将时区设置为 UTC,它就可以工作!

为什么?

很简单,因为 DST。当 DST 开始或结束时,日子不是长 24 小时(而是 23 或 25)。所以,当你用 86400 秒(即 24 小时)计算时,这是行不通的!

将时区设置为不使用 DST 的 UTC 是一种解决方法。但是,在我看来,最干净的解决方案是使用 DateTime 类并让它进行数学运算:http: //php.net/datetime 这些函数具有对时区的内置支持,因此它们可以正确处理 DST。

于 2013-06-11T23:41:11.400 回答
1

不要使用你自己的代码来做 php 已经做的事情。

尝试这个:

$datetime1 = new DateTime('2013-10-28');
$datetime2 = new DateTime('2013-11-01');
$interval = $datetime1->diff($datetime2);
echo $interval->format('%R%a days');

该输出为+4天。

希望这可以帮助你

这是有关日期时间函数的官方文档,您可以使用它们进行所有操作:http: //php.net/manual/en/datetime.diff.php

于 2013-06-11T16:22:08.737 回答
1

这可能与本地主机上的 php 设置与客户端服务器上的差异有关。我过去所做的是比较每个的 phpinfo() 以查看问题可能出在哪里。也许是 php 的日期配置?

于 2013-06-11T16:17:08.050 回答