29

日期(作为 Date 时间类型)存储在我的数据库中,如下所示:31.10.2012
当我在 UI 中显示它时,默认情况下它呈现如下:2012-10-31
我使用它转换它<f:convertDateTime pattern="dd.MM.yyyy" />并且意外地变成
30.10.2012

正如预期的那样SimpleDateconverter,使用相同日期和相同格式字符串的31.10.2012, 会返回 。

我错过了什么?

谢谢

编辑:对于存储为Timestamp相同转换的日期会产生正确的结果,所以我认为它与Date解释为确切的午夜有关,而这又可能被解释为属于 2 个不同的日子。但我仍然不知道在哪里定义行为以及最好的解决方法是什么。

4

1 回答 1

82

这无疑是一个与时区相关的问题。

JSF 在日期/时间转换中默认为 GMT (UTC)。因此,如果您的服务器平台默认时区是 GMT+X(不是 GMT-X),那么时间将返回过去 X 小时数。如果时间已经是 00:00:00(午夜),那么日期甚至会回到过去的一天。

无论如何,有两种标准方法可以实现您的功能要求:

  1. 通过将以下上下文参数添加到,告诉 JSF 使用服务器平台默认时区而不是所有日期/时间转换web.xml

    <context-param>
        <param-name>javax.faces.DATETIMECONVERTER_DEFAULT_TIMEZONE_IS_SYSTEM_TIMEZONE</param-name>
        <param-value>true</param-value>
    </context-param>
    
  2. 更改 every<f:convertDateTime>以明确指定特定于 webapp 的时区。由于您位于德国并且日期格式模式也证实了这一点,因此我假设 CET。

    <f:convertDateTime ... timeZone="CET" />
    

在任何情况下,都不建议在整个应用程序中使用非通用时区甚至混合时区。建议将所有层和环境中的时区设置为 UTC。不仅在服务器和前端层和表示层,而且在 SQL 数据库和后端层和持久层。这样,代码对时区和 DST(!) 相关问题不敏感,如果需要,您可以只在演示期间专注于更改时区。

也可以看看:

于 2012-09-10T12:25:42.220 回答