我发现了类似的问题,但是没有答案对我有帮助。

因此,我有2个对象具有反向指针关系。
家长:

@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);

Json表示的“a”是循环的“请参阅下文”:

{“元素B”:{“a”:{“元素B”:{“a”:{“元素B”:{“a”:{“元素
B“:{” a“:{”元素B“:{” a“:{”元素B“:{” a“:{”元素
B“:{” a“:{”元素B“:{” a“:{”元素B“:{” a“:{” .........

并且stacktrace也是循环的:


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中)

最佳答案

以下内容应有所帮助:

演示代码

您的映射是正确的。您可以使用以下演示代码进行验证。

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批注,并且我已将其删除。如果有演示代码,它们也将以相同的方式工作。



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;
    }

}

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,则在当前配置中,将选择Jackson作为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;
    }

}

有关更多信息
  • http://blog.bdoughan.com/2011/08/json-binding-with-eclipselink-moxy.html
  • http://blog.bdoughan.com/2012/05/moxy-as-your-jax-rs-json-provider.html
  • http://blog.bdoughan.com/2010/07/jpa-entities-to-xml-bidirectional.html
  • 关于json - @XmlInverseReference注释不起作用,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14031963/

    10-16 06:07