我正在获取系统当前时区:
Calendar calendar = new GregorianCalendar();
TimeZone systemTimeZone = calendar.getTimeZone();
- 如果我从 Java main 方法运行,它会给出正确的系统时区。
- 如果我从网络应用程序(从 REST Web 服务)运行,它会提供
Asia/Irkutsk
作为时区。
但是这是错误的,为什么?
最佳答案
tl;博士
- 使用java.time类。
- 明确指定您想要/预期的时区。
示例:
ZonedDateTime // Represents a moment as seen through the wall-clock time used by the people of a particular region.
.now( // Capture the current moment as seen in this time zone.
ZoneId.of( "Asia/Kolkata" ) // Real time zone names are in `Continent/Region` format. Never use 2-4 letter pseudo-zones such as `IST`, `EST`, or `CST`.
)
通常最好在大部分工作中使用 UTC。
Instant.now() // Capture current moment in UTC.
详细信息
JVM保留默认时区。除非您指定,否则将隐式应用此默认值。
当您在本地运行 Java 应用程序时,会隐式应用本地 JVM 的当前默认时区。
当您运行 Java Web 应用程序时,将隐式应用 Servlet 容器的 JVM 的当前默认时区。
我建议您停止使用可怕的日期时间类,例如Calendar
。这些现在已经成为遗留物,多年前已被 JSR 310 中定义的现代 java.time 类所取代。
我强烈建议始终指定您想要/预期的时区。默认区域超出了程序员的控制范围。系统管理员或 JVM 内任何应用程序中的任何其他代码都可以在应用程序运行时更改默认时区。
要捕获 UTC 中的当前时刻,请使用Instant
。
Instant instant = Instant.now() ; // Capture current moment in UTC.
要捕获特定时区的当前时刻,请使用 ZonedDateTime
。
ZoneId z = ZoneId.of( "Africa/Tunis" ) ;
ZonedDateTime zdt = ZonedDateTime.now( z ) ;
<小时/>
关于java.time
java.time框架内置于 Java 8 及更高版本中。这些类取代了麻烦的旧类 legacy日期时间类,例如 java.util.Date
, Calendar
, & SimpleDateFormat
.
要了解更多信息,请参阅 Oracle Tutorial 。并在 Stack Overflow 上搜索许多示例和解释。规范为JSR 310 .
Joda-Time项目,现在位于 maintenance mode ,建议迁移到java.time类。
您可以直接与数据库交换java.time对象。使用JDBC driver符合JDBC 4.2或稍后。不需要字符串,不需要 java.sql.*
类。
从哪里获取java.time类?
- Java SE 8 , Java SE 9 , Java SE 10 , Java SE 11以及后来的版本 - 具有捆绑实现的标准 Java API 的一部分。
- Java 9 添加了一些小功能和修复。
- Java SE 6和 Java SE 7
- 大多数 java.time 功能已向后移植到 ThreeTen-Backport 中的 Java 6 和 7 .
- Android
- Android 的更高版本捆绑了 java.time 类的实现。
- 对于早期的 Android (<26),ThreeTenABP项目适应ThreeTen-Backport (上文提到的)。请参阅How to use ThreeTenABP… .
ThreeTen-Extra项目通过附加类扩展了 java.time。该项目是 java.time future 可能添加的内容的试验场。您可能会在这里找到一些有用的类,例如 Interval
, YearWeek
, YearQuarter
,和more .
关于java - 为什么时区与 java 中的 main 方法和表单 Web 应用程序不同,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21826128/