我需要在xsd中使用<any>
元素来实现可伸缩性。所以我使用xsd如下所示。
<complexType name="AddInput">
<sequence>
<element name="First" type="int"></element>
<element name="Sec" type="int"></element>
<any processContents="lax" namespace="##any" minOccurs="0" maxOccurs="unbounded"></any>
</sequence>
</complexType>
我已经定义了一个复杂的对象放置到<any>
占位符中,使用ObjectFactory(@XMLRegistry,@ XmlElementDecl)但是如果我在代码下面运行,我还是
org.apache.xerces.dom.ElementNSImpl
而不是JAXBElementObject。我在谷歌搜索,我看到JAXBContext应该知道架构。但我不确定,如何使JAXBContext知道我的复杂对象。任何想法都会有所帮助。
List<Object> elemList = (List<Object>)input.getAny();
for(Object elem : elemList){
System.out.println(elem.getClass());
}
答案 0 :(得分:1)
如果您使用如下所示的JAX-RS方法,则使用的JAXBContext
相当于拨打以下电话JAXBContext.newInstance(Foo)
@GET
@Produces(MediaType.APPLICATION_XML)
@Path("{id}")
public Foo read(@PathParam("id") long id) {
return entityManager.find(Foo.class, id);
}
如果您希望JAXBContext
了解您从XML架构生成的所有类,可以使用JAXBContext
将ContextResolver
与域对象相关联。
import java.io.*;
import java.util.*;
import javax.ws.rs.Produces;
import javax.ws.rs.ext.*;
import javax.xml.bind.*;
import org.eclipse.persistence.jaxb.JAXBContextFactory;
@Provider
@Produces(MediaType.APPLICATION_XML)
public class FooContextResolver implements ContextResolver<JAXBContext> {
private JAXBContext jc;
public FooContextResolver() {
try {
jc = JAXBContext.newInstance("com.example.foo");
} catch(JAXBException e) {
throw new RuntimeException(e);
}
}
public JAXBContext getContext(Class<?> clazz) {
if(Foo.class == clazz) {
return jc;
}
return null;
}
}
示例强>
答案 1 :(得分:0)