如下所示,
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
部分?
答案 0 :(得分:8)
使用此代码:
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);
<强>解释强>
代码使用给定的factory method期望ISO-8601格式的本地时间戳的字典表示。由于LocalDateTime
不引用任何时区,因此toString()
的输出不能包含时区偏移量。结果:XMLGregorianCalendar
将时区偏移视为“未设置”。
<强>校正:强>
原始代码并没有特别关注currentUTCTime.toString()
格式化输出的ISO变体。但是,如果这些部分等于零,java.time-API
将产生没有秒或纳秒的输出。这在ISO中是完全合法的,但W3C联盟使第二部分非可选。班级XMLGregorianCalendar
密切关注这个偏离的规范。因此,在这个特殊的边缘情况下,使用简单的字符串连接在上面显示的hack。非常感谢@ Dave的评论。顺便说一句,也可以使用此评论中建议的currentUTCTime.format(DateTimeFormatter.ISO_DATE_TIME)
(而不是显示的黑客)。