即使有大约 15 年的 Java 经验,人们总是会在处理日期和时间的话题上磕磕绊绊......
情况如下:我从某个外部系统获得时间戳作为String
表示。时间戳的语义是它代表一个 UTC 日期。这个时间戳必须放在一个实体中,然后放在一个TIMESTAMP
字段中的 PostgreSQL 数据库中。此外,我需要将与本地时间(在我的情况下为 CEST)相同的时间戳放入实体中,然后放入TIMESTAMP WITH TIME ZONE
字段中的数据库中。
什么是正确的方法来确保无论执行代码的机器的设置是什么,时间戳都正确存储在实体中(以使用其他 UTC 时间戳进行一些验证)和数据库中(稍后在报告中使用它们上)?
这是代码,在我的本地机器上运行良好:
SimpleDateFormat sdfUTC = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS");
sdfUTC.setTimeZone(TimeZone.getTimeZone("UTC"));
Date utcTimestamp = sdfUTC.parse(utcTimestampString);
// getMachinesTimezone is some internal util method giving the TimeZone object of the machines Location
Calendar localTimestamp = new GregorianCalendar(getMachinesTimezone());
localTimestamp.setTimeInMillis(utcTimestamp.getTime());
但是在服务器上执行相同的代码时,会导致不同的时间,所以我认为这不是正确的处理方式。有什么建议么?
PS:我在这个论坛上搜索时读到了 Joda Time,但是在给定的项目中我无法引入新的库,因为我只更改了现有的模块,所以我必须使用标准的 JDK1.6