我一直在这个问题上停留了一段时间,并希望能朝着正确的方向前进。我正在尝试正确编组一个复杂的对象,除了一个特定的关系之外,所有内容都正确导出到 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:type在AbstractClassA上正确定义,但在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>
我将不胜感激朝着正确的方向前进,非常感谢!