WEB应用程序如何保证时间处理时区的正确性?

在web应用开发中,经常将当前系统时间作为时间信息传给数据库保存,然后在后边的客户端浏览器访问时,有时会发现时间不是我们期望的时间,而是错误的时区的时间。

要搞清楚这个问题,我们必须从几个方面着手去保证时间时区的正确处理。

首先要明白几个问题:

1. 数据库支持timestamp和timestamptz两种类型的数据,你需要了解你的数据库表字段使用的是那种类型。他们的区别具体可以参考我上篇博文:

postgresql 数据库timezone设置,以及TIMESTAMPTZ和TIMESTAMP数据类型的选择_Tom098的博客-CSDN博客

2.你的数据库连接所使用的时区。

3. 你的web应用所在的服务器的时区。

4. 你的数据库的时区设置。

这些都明确后,那你的应用基本上时间就不会出现时区转换错误。

但是,现在很多应用都是部署在云上,我们并不能依赖web应用所在的服务器的时区,因为他很有可能是UTC + 0时区,而我们期待的时区是UTC + 8(GMT + 8, Asia/Shanghai)或者其他时区,所以这时,我们在写代码时,生成时间就不能简单的使用像LocalDateTime.now()这样的函数简单的生成时间然后保存到数据库,因为他很有可能不是我们期待的时区的时间。这时我们可以强行使用做过时区转换的时间,比如使用如下代码生成时间:

ZonedDateTime.now(ZoneId.of("Asia/Shanghai")).toLocalDateTime()

 还有的情况是你的时间信息是从第三方获取到的,并且第三方服务返回的数据timestamp部分,对应的时区跟你的应用不一致,那这个时候保存数据库时就需要多方面考虑,可能需要对时间转换成跟你期待的,或者数据库时区一致的时间。

总之,这个时间时区问题是跟多方面相关的,可以在多处设置。从你自己的代码,比如上边的,到数据库连接时区,数据库时区,以及数据库表字段使用的是timestamp还是timestamptz都有关系,这里就不展开了,具体可以参考上边的文档链接。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值