首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将xmlGregorianCalendar转换为日期和反向

将xmlGregorianCalendar转换为日期和反向
EN

Stack Overflow用户
提问于 2019-03-29 15:50:10
回答 1查看 2K关注 0票数 0

我,我有一个弹簧引导应用程序。具体而言,我想要的是在他的上下文实体中转换一个类(其中包含nestet对象字段)。示例:

代码语言:javascript
复制
 public class example{
String string;
ObjectExample object;
}
public class ObjectExample{
String oneString;
XMLGregorianCalendar date;
}

这个2对象在另一个包中也被标记为实体,但是在ObjectExampleEntity中我有日期而不是XMLGregorianCalendar,如下面的示例所示

@实体

代码语言:javascript
复制
public class example{
String string;
ObjectExample object;
}

@实体

代码语言:javascript
复制
public class ObjectExample{
String oneString;
Date date;
}

因为我有一个大模型和一个大实体(以上只是一个例子)和许多嵌套类,所以我使用dozer将模型转换为类。例如,考虑只为父示例类创建存储库jpa。我想知道如何与推土机从日期(实体)转换为XMLGregorianCalendar (模型)和反向。我重复一遍,模型和实体是平等的。唯一的区别是日期的类型。谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-03-31 04:39:32

我假设:

  • 由于您的变量名为date,它包含一个日历日期(没有一天中的时间)。
  • 您被绑定到XMLGregorianCalendar,因为它超出了您的控制范围,但是您可以更改实体端的类型。

基于这些假设,我建议在实体端使用LocalDate。它是java.time的一部分,是现代Java和time的一部分,表示的正是一个没有时间的日期。您使用的Date类设计糟糕,长期过时,不推荐使用。另外,尽管Date的名字从来不代表日期,但却代表了时间的一点。

还有更多选择。我要介绍三位。

备选方案1:转移单个字段

XMLGregorianCalendarLocalDate

代码语言:javascript
复制
    DatatypeFactory xmlFactory = DatatypeFactory.newInstance();
    XMLGregorianCalendar wsDate = xmlFactory
            .newXMLGregorianCalendarDate(2019, DatatypeConstants.MARCH, 30,
                    DatatypeConstants.FIELD_UNDEFINED);

    // Validate
    if ((wsDate.getHour() != 0 && wsDate.getHour() != DatatypeConstants.FIELD_UNDEFINED)
            || (wsDate.getMinute() != 0 && wsDate.getMinute() != DatatypeConstants.FIELD_UNDEFINED)
            || (wsDate.getSecond() != 0 && wsDate.getSecond() != DatatypeConstants.FIELD_UNDEFINED)
            || (wsDate.getMillisecond() != 0 && wsDate.getMillisecond() != DatatypeConstants.FIELD_UNDEFINED)) {
        System.out.println("Warning: time of day will be lost in conversion");
    }
    if (wsDate.getTimezone() != DatatypeConstants.FIELD_UNDEFINED) {
        System.out.println("Warning: UTC offset will be lost in conversion");
    }

    // Convert
    LocalDate entityDate = LocalDate.of(wsDate.getYear(), wsDate.getMonth(), wsDate.getDay());
    System.out.println(entityDate);

在本例中,输出如下:

2019-03-30

LocalDateXMLGregorianCalendar

代码语言:javascript
复制
    LocalDate entityDate = LocalDate.of(2019, Month.MARCH, 31);

    XMLGregorianCalendar wsDate = xmlFactory.newXMLGregorianCalendarDate(
            entityDate.getYear(),
            entityDate.getMonthValue(),
            entityDate.getDayOfMonth(),
            DatatypeConstants.FIELD_UNDEFINED);
    System.out.println(wsDate);

2019-03-31

这种方法的优点是:它非常简单。缺点:您和您的读者需要注意按正确的顺序提到字段。

选项2:通过字符串进行转换

代码语言:javascript
复制
    // Validate as before

    // Convert
    LocalDate entityDate = LocalDate.parse(wsDate.toXMLFormat());

结果和以前一样。

代码语言:javascript
复制
    XMLGregorianCalendar wsDate
            = xmlFactory.newXMLGregorianCalendar(entityDate.toString());

优点:很简单,结果正确也就不足为奇了。缺点:对我来说,把格式格式化成字符串只是为了把它解析回来,这感觉是一种浪费。

选项3:通过GregorianCalendarZonedDateTime进行转换

代码语言:javascript
复制
    ZonedDateTime zdt = wsDate.toGregorianCalendar().toZonedDateTime();

    // Validate
    if (! zdt.toLocalTime().equals(LocalTime.MIN)) {
        System.out.println("Warning: time of day will be lost in conversion");
    }
    if (! zdt.getZone().equals(ZoneId.systemDefault())) {
        System.out.println("Warning: UTC offset will be lost in conversion");
    }

    // Finish conversion
    LocalDate entityDate = zdt.toLocalDate();

另一种方式是:

代码语言:javascript
复制
    // It doesn’t matter which time zone we pick
    // since we are discarding it after conversion anyway
    ZonedDateTime zdt = entityDate.atStartOfDay(ZoneOffset.UTC);
    GregorianCalendar gCal = GregorianCalendar.from(zdt);
    XMLGregorianCalendar wsDate = xmlFactory.newXMLGregorianCalendar(gCal);
    wsDate.setTime(DatatypeConstants.FIELD_UNDEFINED, DatatypeConstants.FIELD_UNDEFINED,
            DatatypeConstants.FIELD_UNDEFINED, DatatypeConstants.FIELD_UNDEFINED);
    wsDate.setTimezone(DatatypeConstants.FIELD_UNDEFINED);

我在这里介绍的验证有点简单,但也不太严格。如果您想要严格的验证,您可以只使用以前的验证。

优点:我认为这是官方的方式,至少它使用了所提供的转换方法。我喜欢的是,转换本身是直接和简短的。缺点:当转换为XMLGregorianCalendar时,我们需要手动将未使用的字段设置为未定义的字段,这使得它变得冗长。

结论

我提出了三种方案,各有优缺点。当然,您也可以混合使用,但是使用类似的转换方式最终可能不会让人感到困惑。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55421086

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档