【问题标题】:Java date with timezone changed secretly?带时区的 Java 日期秘密更改?
【发布时间】:2012-10-16 01:20:54
【问题描述】:

我们有一个 web 服务应用程序,它总是以 UTC 格式输入时间

2012-12-06T05:00:00.000Z

这是将日期解析为 java util Date 对象的代码

 private static final Pattern PATTERN = Pattern.compile(
"(\\d{4})(?:-(\\d{2}))?(?:-(\\d{2}))?(?:[Tt](?:(\\d{2}))?(?::(\\d{2}))?(?::(\\d{2}))?(?:\\.(\\d{3}))?)?([Zz])?(?:([+-])(\\d{2}):(\\d{2}))?");


  Matcher m = PATTERN.matcher(dateString);
  Calendar c = Calendar.getInstance(TimeZone.getTimeZone("GMT"));
  int hoff = 0, moff = 0, doff = -1;
  if (m.group(9) != null) {
    doff = m.group(9).equals("-") ? 1 : -1;
    hoff = doff * (m.group(10) != null ? Integer.parseInt(m.group(10)) : 0);
    moff = doff * (m.group(11) != null ? Integer.parseInt(m.group(11)) : 0);
  }
  c.set(Calendar.YEAR,        Integer.parseInt(m.group(1)));
  c.set(Calendar.MONTH,       m.group(2) != null ? Integer.parseInt(m.group(2))-1 : 0);
  c.set(Calendar.DATE,        m.group(3) != null ? Integer.parseInt(m.group(3)) : 1);
  c.set(Calendar.HOUR_OF_DAY, m.group(4) != null ? Integer.parseInt(m.group(4)) + hoff: 0);
  c.set(Calendar.MINUTE,      m.group(5) != null ? Integer.parseInt(m.group(5)) + moff: 0);
  c.set(Calendar.SECOND,      m.group(6) != null ? Integer.parseInt(m.group(6)) : 0);
  c.set(Calendar.MILLISECOND, m.group(7) != null ? Integer.parseInt(m.group(7)) : 0);
  return c.getTime();

最近观察到一件奇怪的事情,当应用程序首次启动时,返回的日期将正确打印为 2012 年 12 月 6 日星期四 00:00:00 EST

因为我们在 EST 时区。然后过了一会儿,经过一些执行,即使没有重新启动应用程序,相同的日期也会打印为 2012 年 12 月 6 日星期四 05:00:00 UTC

我一直在深入研究应用程序,但没有看到任何会重置应用程序默认时区的更改。怎么会这样?我们开始研究这个已经一周了,我们仍然一无所知:-(

另外,是否有办法确保应用程序继续使用系统时区,因为它不会改变?

非常感谢任何帮助/提示

【问题讨论】:

  • 你为什么不使用 javax.text.SimpleDateFormat.parse(String) ???
  • 这是我们从第一天开始就一直在使用的一些第 3 方代码。

标签: java date timezone


【解决方案1】:

不幸的是,任何写得不好的代码决定调用TimeZone.setDefault,都可以在您的应用程序下更改时区。当第三方代码调用该方法时,我们实际上在我们的应用程序中被这个问题所困扰。不幸的是,解决方案是从不依赖于应用程序开始之后的默认时区。我们有一个核心类,它在启动时获取默认 TimeZone,所有后续代码需要使用系统默认值输出日期不要忘记 TimeZone 是可变的!)。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-06-28
    • 2014-02-16
    • 2017-04-18
    • 2021-06-08
    相关资源
    最近更新 更多