如何为php Web应用程序管理不同国家/地区不同用户的时区?

时间:2014-06-26 08:40:33

标签: php mysql timezone

我正在开发Web应用程序。该应用程序拥有来自不同国家/地区的不同用户。

我曾经使用UTC时间戳来管理他们的注册。它对我来说很好。

但是当我检查帐户的到期日期时会出现问题。

例如 -

根据亚洲/加尔各答时区,假设注册有效期为15天,印度用户的注册日期为2014年6月11日,在数据库表中我已将注册日期存储为Unix时间戳格式(服务器设置为UTC时区) ,在第16天我想要使他的帐户到期,当我通过计算今天的日期(时间戳中的日期,使用PHP的strtotime()函数将日期转换为时间戳)执行查询时,我发现在一天中存在差异。 如何处理这类情况?这不仅是注册问题,还有一些其他条件。 此外,如果我想使用cron作业发送注册过期电子邮件,它将如何运作?

2 个答案:

答案 0 :(得分:0)

/**
 * @function getusertimezonedifference return timezone difference with UTC
 * @param integer $timezonedifference       optional
 * @return string time
 * @Comment Get User TimeZone Difference
 */
public function getusertimezonedifference($timezone = "Asia/Kolkata", $changetoUTC=false, $flg_array=false)
{
    #$timezone = "Asia/Kolkata";+5.30
    #$timezone = "America/Anchorage";-9
    #$timezone = "America/Los_Angeles";-8
    #$timezone = "America/Dawson_Creek";-8
    #$timezone = "America/Chicago";-6
    #$timezone = "America/New_York";-5
    #$timezone = "America/Halifax";-4
    #$timezone = "America/St_Johns";#3.30
    $dayLightFlag = false;
    $system_timezone = date_default_timezone_get();
    $local_timezone = "UTC";
    date_default_timezone_set($local_timezone);
    $local = date("Y-m-d H:i:s");
    date_default_timezone_set("GMT");
    $gmt = date("Y-m-d H:i:s");
    date_default_timezone_set($timezone);
    $required = date("Y-m-d H:i:s");
    date_default_timezone_set($system_timezone);
    $diff1 = (strtotime($gmt) - strtotime($local));
    $diff2 = (strtotime($required) - strtotime($gmt));
    if($changetoUTC) {$diff2 =  (-1*$diff2);}
    // extract hours
    $hours = floor($diff2 / (60 * 60));
    // extract minutes
    $divisor_for_minutes = $diff2 % (60 * 60);
    $minutes = floor($divisor_for_minutes / 60);
    // extract the remaining seconds
    $divisor_for_seconds = $divisor_for_minutes % 60;
    $seconds = ceil($divisor_for_seconds);

    //create string HH:MM:SS
    $ret = $hours.":".(($minutes>9)?$minutes:"0$minutes").":".(($seconds>9)?$seconds:"0$seconds");
    if($flg_array){$ret = array($hours, ((abs($minutes)>9)?$minutes:"0$minutes"), ($seconds>9)?$seconds:"0$seconds");}
    return ($ret);
}

答案 1 :(得分:-1)

你需要做几步。

  • 所有国家/地区的数据库表
  • 在注册或表单提交时获取IP地址
  • 根据IP检查详细信息并获取国家和时区
  • 沿记录信息保存国家/地区和时区

通过这种方式,您可以沿着创建者的时区维护记录。

根据基于时区的记录到期,您可以根据他们的时区进行检查。

假设我在巴基斯坦,时区是5岁以上。所以到期步骤也应该遵循我的时区。