一个关于时区的bug

远子 •  2020年05月25日

起因: 在 Apollo 中配置了某活动的开始时间是 2020-05-15, 代码中的逻辑判断如下:

const nowTime = new Date().getTime();
const startTime = new Date('2020-05-15').getTime();
if (nowTime > startTime) {
    // 活动开始
}

表现: 测试在 2020-05-15 00:02:00 左右时测试页面发现活动并未开始, 直到第二天早上上班时(8点半左右)活动才开始.

原因: 一般来说 new Date('2020-05-15').getTime() 方法返回的是零点的时间戳,
实际上如果系统的本地时间是东八时区的话, 会返回 2020-05-15 08:00:00 的时间戳.

在阿里云服务器中通过 date -R 目录查看本地时间:

# +0800 代表东八时区
Fri, 15 May 2020 09:13:52 +0800

MDN 关于 Date.prototype.getTime 的描述为:

getTime() always uses UTC for time representation. For example, a client browser in one timezone,
getTime() will be the same as a client browser in any other timezone.

解决办法: 在配置中补全时分秒的信息, 如: 2020-05-15 00:00:00

(完)