该错误似乎是一个递归错误,该公司要求再次询问公司的工作表,哪个....你得到漂移。我已经搜索了互联网和堆栈溢出,我发现了错误发生的原因,但解决方案总是编写自己的解析器或使用flexjson或其他。我只是想知道是否有解决方案,因为游戏很受欢迎,人们肯定会在一次操作中获取帖子和评论,或者不是吗?
必须有一个解决方案,不需要交换json解析器或编写自己的解析器。
Company.java
package models;
import java.util.*;
import javax.persistence.*;
import play.db.jpa.*;
@Entity
public class Company extends Model {
public String name;
public String address;
public String city;
public String zipcode;
public String country;
public String phonenumber;
public String website;
public String footer;
public String maincontactperson;
public String email;
public String password;
public Blob logo;
@OneToMany(mappedBy = "company", cascade = CascadeType.ALL, orphanRemoval = true, fetch=FetchType.EAGER)
public List<Worksheet> worksheets;
}
}
和
Worksheet.java
package models;
import java.util.*;
import javax.persistence.*;
import play.db.jpa.*;
@Entity
public class Worksheet extends Model {
public String contactname;
public String name;
public String address;
public String phonenumber;
public String city;
public String email;
public String partnumber;
@Lob
public String partdescription;
public String password;
public Date due_date;
public Date in_date;
@Lob
public String notes;
@ManyToOne(cascade=CascadeType.ALL)
public Company company;
...
}
在我的控制器中,我只是运行:
List<Company> companies = Company.FindAll();
renderJSON(companies);
如果没有工作表,则此方法有效,但一旦有工作表,它就会崩溃并显示一英里长的错误消息。这是它的顶部:
00:31:02,623 ERROR ~
@6cbn7gi1o
Internal Server Error (500) for request POST /companies/login
Execution exception
InvocationTargetException occured : null
play.exceptions.JavaExecutionException
at play.mvc.ActionInvoker.invoke(ActionInvoker.java:239)
at Invocation.HTTP Request(Play!)
Caused by: java.lang.reflect.InvocationTargetException
at play.mvc.ActionInvoker.invokeWithContinuation(ActionInvoker.java:557)
at play.mvc.ActionInvoker.invoke(ActionInvoker.java:508)
at play.mvc.ActionInvoker.invokeControllerMethod(ActionInvoker.java:484)
at play.mvc.ActionInvoker.invokeControllerMethod(ActionInvoker.java:479)
at play.mvc.ActionInvoker.invoke(ActionInvoker.java:161)
... 1 more
Caused by: java.lang.StackOverflowError
at java.util.Date.getTimeImpl(Date.java:870)
at java.util.Date.getTime(Date.java:866)
at java.sql.Timestamp.getTime(Timestamp.java:126)
at java.util.Calendar.setTime(Calendar.java:1076)
at java.text.SimpleDateFormat.format(SimpleDateFormat.java:875)
at java.text.SimpleDateFormat.format(SimpleDateFormat.java:868)
at java.text.DateFormat.format(DateFormat.java:316)
at com.google.gson.internal.bind.DateTypeAdapter.write(DateTypeAdapter.java:90)
at com.google.gson.internal.bind.DateTypeAdapter.write(DateTypeAdapter.java:41)
at com.google.gson.internal.bind.TypeAdapters$22$1.write(TypeAdapters.java:522)
at com.google.gson.internal.bind.TypeAdapters$22$1.write(TypeAdapters.java:515)
....
at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1.write(ReflectiveTypeAdapterFactory.java:89)
at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.write(ReflectiveTypeAdapterFactory.java:195)
at com.google.gson.Gson$FutureTypeAdapter.write(Gson.java:879)
at com.google.gson.internal.bind.TypeAdapterRuntimeTypeWrapper.write(TypeAdapterRuntimeTypeWrapper.java:68)
at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$1.write(ReflectiveTypeAdapterFactory.java:89)
at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.write(ReflectiveTypeAdapterFactory.java:195)
答案 0 :(得分:3)
恕我直言,这不是一个错误,你的模型中有一个递归,框架无法真正知道它应该如何序列化模型。
我通常使用@Expose注释来解决这个问题。将它添加到要在序列化JSON中显示的所有成员,并创建一个辅助方法,执行如下操作:
Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
String json = gson.toJson(your_model_instance);
您也可以选择按照评论中的建议实现JsonSerializer接口。
答案 1 :(得分:0)
在another question中,我找到了this class的链接,这似乎很好地解决了循环引用问题(并且没有修改模型类)。
有关示例,请参阅已链接问题的已批准答案。