简体   繁体   English

Gson.toJson Stackoverflow错误

[英]Gson.toJson Stackoverflow error

I am using play framework in java (ebean is my ORM), and I have this class: 我在Java中使用播放框架(ebean是我的ORM),并且具有此类:

@Entity
@Table(name = "reservation")
public class Reservation extends Model implements Validation {
    @Id
    @Column(name = "reservationId", columnDefinition = "BIGINT")
    @GeneratedValue(strategy = GenerationType.AUTO)
    @JsonIgnore
    private long reservationId;
    @Column(name = "restaurantId", columnDefinition = "BIGINT")
    private long restaurantId;
    @Column(name = "dateTime" , columnDefinition = "DATETIME")
    @JsonFormat(pattern = "dd/mm/yyyy HH:mm:ss")
    @Formats.DateTime( pattern = "dd/mm/yyyy HH:mm:ss")
    private Timestamp dateTime;
    @Column(name = "guestCount")
    private int guestCount;
    @Column(length = 300)
    private String note;

    public static Reservation.Finder<String, Reservation> find = new Model.Finder<String, Reservation>(String.class, Reservation.class);

and I am trying to serialize it using Gson library. 我正在尝试使用Gson库对其进行序列化。 I tried to do this 我试图做到这一点

return new Gson().toJson(Reservation.find.where().eq("reservationId", id).findUnique(););

but I always get this error: 但我总是得到这个错误:

akka.actor.ActorSystemImpl - Uncaught fatal error from thread [application-akka.actor.default-dispatcher-2] shutting down ActorSystem [application]
java.lang.StackOverflowError: null
    at java.text.DateFormatSymbols.initializeData(DateFormatSymbols.java:684) ~[na:1.8.0_71]
    at java.text.DateFormatSymbols.<init>(DateFormatSymbols.java:146) ~[na:1.8.0_71]
    at sun.util.locale.provider.DateFormatSymbolsProviderImpl.getInstance(DateFormatSymbolsProviderImpl.java:85) ~[na:1.8.0_71]
    at java.text.DateFormatSymbols.getProviderInstance(DateFormatSymbols.java:359) ~[na:1.8.0_71]
    at java.text.DateFormatSymbols.getInstance(DateFormatSymbols.java:335) ~[na:1.8.0_71]
    at java.util.Calendar.getDisplayName(Calendar.java:2110) ~[na:1.8.0_71]
    at java.text.SimpleDateFormat.subFormat(SimpleDateFormat.java:1125) ~[na:1.8.0_71]
    at java.text.SimpleDateFormat.format(SimpleDateFormat.java:966) ~[na:1.8.0_71]
    at java.text.SimpleDateFormat.format(SimpleDateFormat.java:936) ~[na:1.8.0_71]
    at java.text.DateFormat.format(DateFormat.java:345) ~[na:1.8.0_71]
    at com.google.gson.internal.bind.DateTypeAdapter.write(DateTypeAdapter.java:83) ~[gson-2.5.jar:na]
    at com.google.gson.internal.bind.DateTypeAdapter.write(DateTypeAdapter.java:41) ~[gson-2.5.jar:na]
    at com.google.gson.internal.bind.TypeAdapters$26$1.write(TypeAdapters.java:607) ~[gson-2.5.jar:na]
    at com.google.gson.internal.bind.TypeAdapters$26$1.write(TypeAdapters.java:600) ~[gson-2.5.jar:na]

I was reading a lot about this, and I understand that it may be that infinite loop occurs somewhere while serializing the Reservation object, but since the object does not have any relationship to any other class, I don't understand why it happens. 我已经阅读了很多有关此的内容,并且我了解到在序列化Reservation对象时可能在某处发生了无限循环,但是由于该对象与任何其他类没有任何关系,因此我不明白为什么会发生这种情况。

The problem was with Gson. 问题出在格森身上。 Gson has known issues with converting ebean into Json. Gson在将ebean转换为Json方面存在已知问题。 I replaced it with jackson and it works now. 我将其替换为杰克逊,现在可以使用了。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM