喜欢下面的,
LocalDateTime currentUTCTime = LocalDateTime.now(ZoneId.of("UTC"));
String reqPattern = currentUTCTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss:SSS"));
System.out.println("Required pattern: " + reqPattern);
GregorianCalendar calendar = GregorianCalendar.from(currentUTCTime.atZone(ZoneId.systemDefault()));
XMLGregorianCalendar xcal = DatatypeFactory.newInstance().newXMLGregorianCalendar(calendar);
System.out.println("But Showing As :" + xcal);
我希望输出为
2015-06-18 11:59:15:135
,但是当我将 xcal
设置为
一个带有 XMLGregorianCalender
的 XML 标签,它显示为 2015-06-18T11:59:15.135+05:30
。
如何去除
+05:30
部分?
使用此代码:
LocalDateTime currentUTCTime = LocalDateTime.now(); // using system timezone
String iso = currentUTCTime.toString();
if (currentUTCTime.getSecond() == 0 && currentUTCTime.getNano() == 0) {
iso += ":00"; // necessary hack because the second part is not optional in XML
}
XMLGregorianCalendar xml =
DatatypeFactory.newInstance().newXMLGregorianCalendar(iso);
说明:
代码使用给定的工厂方法,期望以 ISO-8601 格式按字典顺序表示本地时间戳。由于
LocalDateTime
不引用任何时区,因此其通过 toString()
的输出不能包含时区偏移量。结果:XMLGregorianCalendar
认为时区偏移量“未设置”。
更正:
原始代码并没有特别关心
currentUTCTime.toString()
格式化输出的 ISO 变体。但是,如果这些部分等于零,则 java.time-API
会产生没有秒或纳秒的输出。这在 ISO 中是完全合法的,但 W3C 联盟已将第二部分设为非可选。 XMLGregorianCalendar
类紧密遵循这个偏离的规范。因此,上面显示的技巧在这种特殊的边缘情况下使用简单的字符串连接。非常感谢@Dave 的评论。顺便说一句,按照此评论中的建议使用 currentUTCTime.format(DateTimeFormatter.ISO_DATE_TIME)
也是可能的(而不是显示的 hack)。
我用过这个,效果很好。
String localDateTimeString = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.SSS").format(localDateTime);
XMLGregorianCalendar xmlGregorianCalendar = DatatypeFactory.newInstance().newXMLGregorianCalendar(localDateTimeString);