1

我一直在这个问题上停留了一段时间,并希望能朝着正确的方向前进。我正在尝试正确编组一个复杂的对象,除了一个特定的关系之外,所有内容都正确导出到 XML。我正在使用 Spring @Endpoint 实现。

引起我问题的类是 AbstractDependent。

我的模型如下(示例代码):

@XmlRootElement
public class RootClass{

    private Set<AbstractClassA> classASet;
    private Client client;

    //... getters/setters (no special annotations)
}

@XmlRootElement
public class Client extends AbstractApplicant{
    private List<AbstractDependent> dependentList;

    //..more attributes... setter/getters
}

@XmlRootElement
public class Child extends AbstractDependent{
  //class attributes
}

@XmlRootElement
public class Spouse extends AbstractDependent{
  //class attributes
}

//tried putting the @XmlSeeAlso annotation, no success
public abstract class AbstractDependent extends AbstractApplicant{
  //class attributes
}

public abstract class AbstractApplicant{
  //class attributes
}


//No Special annotations
public abstract class AbstractClassA{
  //class attributes
}

//The only special annotation is the XmlRootElement, other attributes are atomic
@XmlRootElement
public class ImplA extends AbstractClassA{
  //class attributes
}

所有类都在同一个包中,我使用 package-info.java 文件来指定命名空间。

我已经检查了 spring 的MarshallingPayloadMethodProcessor中的编组器,并且 JaxB 上下文包括上面提到的所有类,所以这不是问题。

附带说明一下, AsbtractClassA的实现类很好,并且可以使用“type”属性在 xml 中正确翻译。以下是输出示例:

<?xml version="1.0" encoding="UTF-8"?>
<ns3:rootClass xmlns:ns3="http://mynameservice.com/schema/webservice">

    <ns3:abstractClassA xsi:type="ns3:implA">
        <id>1</id>
    </ns3:abstractClassA>
    <ns3:abstractClassA xsi:type="ns3:implB">
        <id>2</id>
    </ns3:abstractClassA>

    <ns3:client>
        <id>15</id>
        <ns3:dependentList>
        <id>17</id>
        <!-- other attributes -->
        </ns3:dependentList>
        <ns3:dependentList>
        <id>18</id>
        <!-- other attributes, excluding the ones from the Child And Spouse class  -->      
        </ns3:dependentList>
    </ns3:client>

</ns3:rootClass>

xsi:typeAbstractClassA上正确定义,但在AbstractDependent上没有正确定义,我似乎无法理解为什么或如何。显然我的模型比这大得多,但dependentList 是唯一导致我出现问题的元素。值得注意的是,将@XmlTransiant元素放在dependentList 上根本没有帮助,它完全从 xml 中排除了对象(许多互联网帖子建议这样做)。

定义的编组器如下,上下文再次包括所有必要的类:

<bean id="jaxbMarshaller" class="org.springframework.oxm.jaxb.Jaxb2Marshaller">
    <property name="packagesToScan">
        <list>
            <value>com.company.*</value>
        </list>
    </property>
</bean> 

一些配置:

<bean id="messageReceiver"
    class="org.springframework.ws.soap.server.SoapMessageDispatcher">
    <property name="endpointAdapters">
        <list>
            <ref bean="defaultMethodEndpointAdapter" />
        </list>
    </property>
</bean> 

<bean id="defaultMethodEndpointAdapter" 
    class="org.springframework.ws.server.endpoint.adapter.DefaultMethodEndpointAdapter">
    <property name="methodReturnValueHandlers">
        <list>
            <ref bean="marshallingPayloadMethodProcessor"/>
        </list>
    </property>
    <property name="methodArgumentResolvers">
        <list>
            <ref bean="marshallingPayloadMethodProcessor"/>
        </list>
    </property>     
</bean>  

<bean id="marshallingPayloadMethodProcessor"
    class="org.springframework.ws.server.endpoint.adapter.method.MarshallingPayloadMethodProcessor">
    <constructor-arg ref="jaxbMarshaller" />
    <constructor-arg ref="jaxbMarshaller" />
</bean> 

我将不胜感激朝着正确的方向前进,非常感谢!

4

1 回答 1

0

经过几个小时的调查,我发现了这个问题。这是由于休眠将仍然延迟加载的对象传递给 MarshallingPayloadMethodProcessor。我刚刚假设对象会在编组之前正确初始化。

我创建了一个自定义 XmlAdapter:

public class HibernatetEntityAdapter extends XmlAdapter<AbstractEntity, AbstractEntity> {

@Override
public AbstractEntity unmarshal(AbstractEntity v) throws Exception {
    return v;
}

@Override
public AbstractEntity marshal(AbstractEntity v) throws Exception {
    return HibernateUtils.unenhanceObject(v);
}

}

现在我简单地在导致我问题的类上添加以下注释:

@XmlJavaTypeAdapter(HibernatetEntityAdapter.class)

谢谢,JP

于 2013-11-19T21:59:52.573 回答