我发现了类似的问题,但没有一个答案对我有帮助。
所以,我有两个具有后向指针关系的对象。 家长:
@XmlRootElement
public class A {
private B b;
@XmlElement(name = "Element B")
public B getB() {
return b;
}
public void setB(B b) {
this.b = b;
}
}
和B:
@XmlRootElement
public class B {
private A a;
@XmlInverseReference(mappedBy = "b")
public A getA() {
return a;
}
public void setA(A a) {
this.a = a;
}
}
我将 jaxb.properties 放在与模型相同的包中。 (javax.xml.bind.context.factory的= org.eclipse.persistence.jaxb.JAXBContextFactory)
在此片段之后:
A a = new A();
a.setB(new B());
a.getB().setA(a);
“ a ”的Json表示是循环的“见下文”:
{“元素B”:{“a”:{“元素B”:{“a”:{“元素B”:{“a”:{“元素 B“:{”a“:{”元素B“:{”a“:{”元素B“:{”a“:{”元素 B“:{”a“:{”元素B“:{”a“:{”元素B“:{”a“:{”.........
并且堆栈跟踪也是循环的:
在 org.codehaus.jackson.map.ser.BeanSerializer.serializeFields(BeanSerializer.java:245) 在 org.codehaus.jackson.map.ser.BeanSerializer.serialize(BeanSerializer.java:212) 在 org.codehaus.jackson.map.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:428) 在 org.codehaus.jackson.map.ser.BeanSerializer.serializeFields(BeanSerializer.java:245) 在 org.codehaus.jackson.map.ser.BeanSerializer.serialize(BeanSerializer.java:212) 在 org.codehaus.jackson.map.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:428) 在 org.codehaus.jackson.map.ser.BeanSerializer.serializeFields(BeanSerializer.java:245)
我认为我没有将MOXy扩展名添加到我的项目中......(刚刚添加到项目eclipselink.jar中)
答案 0 :(得分:1)
以下内容应该有所帮助:
DEMO CODE
您的映射是正确的。您可以使用以下演示代码验证这一点。
package forum14031963;
import java.util.*;
import javax.xml.bind.*;
import org.eclipse.persistence.jaxb.JAXBContextProperties;
public class Demo {
public static void main(String[] args) throws Exception {
Map<String, Object> properties = new HashMap<String, Object>(2);
properties.put(JAXBContextProperties.MEDIA_TYPE, "application/json");
properties.put(JAXBContextProperties.JSON_INCLUDE_ROOT, false);
JAXBContext jc = JAXBContext.newInstance(new Class[] {A.class}, properties);
A a = new A();
a.setB(new B());
a.getB().setA(a);
Marshaller marshaller = jc.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
marshaller.marshal(a, System.out);
}
}
<强>输出强>
以下是运行演示代码的输出。
{
"Element B" : {
}
}
JAVA模型
在您的示例中,@XmlRootElement
注释不是必需的,我已将其删除。如果它们在那里,演示代码也将以相同的方式工作。
的 A 强> 的
package forum14031963;
import javax.xml.bind.annotation.XmlElement;
public class A {
private B b;
@XmlElement(name = "Element B")
public B getB() {
return b;
}
public void setB(B b) {
this.b = b;
}
}
的乙强> 的
package forum14031963;
import org.eclipse.persistence.oxm.annotations.XmlInverseReference;
public class B {
private A a;
@XmlInverseReference(mappedBy = "b")
public A getA() {
return a;
}
public void setA(A a) {
this.a = a;
}
}
的 jaxb.properties 强> 的
要将MOXy指定为JAXB提供程序,您需要在与域模型相同的程序包中包含名为jaxb.properties
的文件,并带有以下条目(请参阅:http://blog.bdoughan.com/2011/05/specifying-eclipselink-moxy-as-your.html)。
javax.xml.bind.context.factory=org.eclipse.persistence.jaxb.JAXBContextFactory
<强> JAX-RS 强>
如果您使用的是JAX-RS,那么在您当前的配置中,杰克逊将被选为JSON提供商。将MOXy作为JSON提供程序的最简单方法是使用MOXyJsonProvider
类。
package org.example;
import java.util.*;
import javax.ws.rs.core.Application;
import org.eclipse.persistence.jaxb.rs.MOXyJsonProvider;
public class CustomerApplication extends Application {
@Override
public Set<Class<?>> getClasses() {
HashSet<Class<?>> set = new HashSet<Class<?>>(2);
set.add(MOXyJsonProvider.class);
set.add(CustomerService.class);
return set;
}
}
了解更多信息