【发布时间】:2014-08-17 00:59:16
【问题描述】:
我正在开发网络应用程序。该应用程序拥有来自不同国家/地区的不同用户。
我曾经使用 UTC 时间戳来管理他们的注册。对我来说效果很好。
但是当我检查帐户的到期日期时会出现问题。
例如-
假设注册有效期为 15 天,并且来自印度的用户,其注册日期为 2014 年 6 月 11 日,按照亚洲/加尔各答时区,在数据库表中,我以 Unix 时间戳格式存储了注册日期(服务器设置为 UTC 时区) ,在第 16 天,我想使他的帐户到期,当我通过比较今天的日期(时间戳中的日期,使用 PHP 的 strtotime() 函数将日期转换为时间戳)执行查询时,我发现一天有差异。 如何处理这类情况?这不仅是注册问题,还有其他一些条件。 另外,如果我想使用 cron 作业发送注册到期的电子邮件,它将如何工作?
【问题讨论】:
-
15 天是 15 天,与时区无关。如果您的服务器注册了用户并记录了注册时间的时间戳,它还能够识别 15 天后的时间。你必须证明你是如何弄错的。
-
谢谢,这适用于注册场景。但是,如果用户希望用户在提供的日期范围内报告某些记录,那么如何比较该用户时区的 MYSQL 查询中的日期?
-
基本上:1) 知道用户在哪个时区(问他),2) 知道您将数据存储在哪个时区(UTC 很好,但只要它是一致的,任何工作都可以) , 3) 根据需要在两个时区之间进行转换。
-
这真的取决于你想要什么。您的意思是在 15 个日历日过后的确切注册时间到期吗?还是在第 15 个日历日的结束?还是在 24 小时(360 小时)的 15 次间隔之后?您是否将用户的时区单独存储在数据库中?另外 - 请记住,并非所有日子都是 24 小时。在具有夏令时的时区中,过渡日为 23 或 25 小时。在一个时区 (
Australia/Lord_Howe) 中,它们是 23.5 或 24.5 小时。 -
在这里显示一些代码也会有所帮助。仅仅说你使用 strtotime 是不够的。请向我们展示一个示例,并提供数据值。另请参阅帮助中心的How to create a Minimal, Complete, and Verifiable example。谢谢。