当尝试序列化类别时,我遇到了 stackoverflow。
例外
警告:StandardWrapperValve[dispatcher]:Servlet.service() for
servlet 调度程序抛出异常 java.lang.StackOverflowError
java.lang.ClassLoader.defineClass1(本机方法) at
java.lang.ClassLoader.defineClass(ClassLoader.java:760) 在
org.apache.felix.framework.BundleWiringImpl$BundleClassLoader.findClass(BundleWiringImpl.java:2279)
在
org.apache.felix.framework.BundleWiringImpl.findClassOrResourceByDelegation(BundleWiringImpl.java:1501)
在
org.apache.felix.framework.BundleWiringImpl.access$400(BundleWiringImpl.java:75)
在
org.apache.felix.framework.BundleWiringImpl$BundleClassLoader.loadClass(BundleWiringImpl.java:1955)
在 java.lang.ClassLoader.loadClass(ClassLoader.java:357) 处
com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:660)
在
com.fasterxml.jackson.databind.ser.BeanSerializer.serialize(BeanSerializer.java:152)
在
com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serializeContents(IndexedListSerializer.java:100)
在
com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serializeContents(IndexedListSerializer.java:21)
在
com.fasterxml.jackson.databind.ser.std.AsArraySerializerBase.serialize(AsArraySerializerBase.java:183)
在
com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:541)
在
com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:644)
在
com.fasterxml.jackson.databind.ser.BeanSerializer.serialize(BeanSerializer.java:152)
类别.java
@Entity
public class Category implements DataObject, Serializable {
@Id
@GeneratedValue
private Long id;
private String title;
private String description;
@ManyToOne @JsonIgnore
private Category parent;
@Override
public long getId() {
return id;
}
@Override
public void setId(long id) {
this.id = id;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public Category getParent() {
return null;//return parent;
}
public void setParent(Category parent) {
// this.parent = parent;
}
public boolean isMainCategory()
{
return true;// return this.parent == null;
}
/**
* Returns the chain of parent categories with the main category on index 0
* @return Chain of categories
*/
public List<Category> getParentChain()
{
List<Category> cats = new ArrayList<>();
Category current = this;
while(!current.isMainCategory())
{
cats.add(current);
current = current.getParent();
}
cats.add(current);
Collections.reverse(cats);
return cats;
}
@Override
public String toString()
{
return this.title;
}
@Override
public boolean equals(Object o)
{
if(!(o instanceof Category))return false;
Category c = (Category)o;
return c.title.equals(this.title);
}
@Override
public int hashCode()
{
return super.hashCode();
}
}
休息控制器功能
@RequestMapping(value="/{id}", method=RequestMethod.GET)
public ResponseEntity<Category> get(@PathVariable("id") long categoryId)
{
Category c = service.getCategoryRepository().ReadValue(categoryId);
if(c == null)
return new ResponseEntity<>(HttpStatus.NOT_FOUND);
return new ResponseEntity<>(c,HttpStatus.OK);
}
Note
即使当我更换return new ResponseEntity<>(c,HttpStatus.OK);
with return new ResponseEntity<>(new Category(),HttpStatus.OK);
当没有任何字段包含值时,我会遇到堆栈溢出。
它与我的其他类一起工作得很好,只有这个类会导致堆栈溢出。
当然可以,@JsonIgnore
完成工作。但是如果我们需要在 JSON 输出中忽略字段怎么办?
解决方案非常简单。
我们通过以下方式注释我们的“有罪”字段@JsonManagedReference
我们关系的一侧的注释(这意味着我们的@ManyToMany
注解)。
And @JsonBackReference
在关系的另一边(其中@OneToMany
已放置)。
就是这样。不再有递归循环。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)