簡體   English   中英

帶有CXF和JAX-WS的XmlJavaTypeAdapter

[英]XmlJavaTypeAdapter with CXF and JAX-WS

我有一個類X,它在用Apache CXFJAX-WS構建的Web服務的Service接口中使用。 這個類X沒有默認構造函數,我想避免使用這個默認構造函數。 我想知道我是否可以使用@XmlJavaTypeAdapter注釋作為解決方案。

ClassXService中的方法:

@WebMethod
@XmlJavaTypeAdapter(ClassXAdapter.class)
public void myMethod(ClassX arg0);

@WebMethod
@XmlJavaTypeAdapter(ClassXAdapter.class)
public ClassX myMethod2();

適配器擴展XmlAdapter並正確定義marshal和unmarshal方法。

但是,無論是否使用XmlJavaTypeAdapter注釋,我總是得到相同的錯誤:

Exception in thread "main" org.apache.cxf.service.factory.ServiceConstructionException
    at org.apache.cxf.jaxb.JAXBDataBinding.initialize(JAXBDataBinding.java:292)
    at org.apache.cxf.service.factory.AbstractServiceFactoryBean.initializeDataBindings(AbstractServiceFactoryBean.java:86)
    at org.apache.cxf.service.factory.ReflectionServiceFactoryBean.buildServiceFromClass(ReflectionServiceFactoryBean.java:438)
    at org.apache.cxf.jaxws.support.JaxWsServiceFactoryBean.buildServiceFromClass(JaxWsServiceFactoryBean.java:682)
    at org.apache.cxf.service.factory.ReflectionServiceFactoryBean.initializeServiceModel(ReflectionServiceFactoryBean.java:501)
    at org.apache.cxf.service.factory.ReflectionServiceFactoryBean.create(ReflectionServiceFactoryBean.java:241)
    at org.apache.cxf.jaxws.support.JaxWsServiceFactoryBean.create(JaxWsServiceFactoryBean.java:202)
    at org.apache.cxf.frontend.AbstractWSDLBasedEndpointFactory.createEndpoint(AbstractWSDLBasedEndpointFactory.java:101)
    at org.apache.cxf.frontend.ServerFactoryBean.create(ServerFactoryBean.java:157)
    at org.apache.cxf.jaxws.JaxWsServerFactoryBean.create(JaxWsServerFactoryBean.java:202)
    at my.package.Main.main(Main.java:35)    
Caused by: com.sun.xml.bind.v2.runtime.IllegalAnnotationsException: 1 counts of IllegalAnnotationExceptions
    my.package.ClassX does not have a no-arg default constructor.
        this problem is related to the following location:
            at my.package.ClassX
            at private my.package.ClassX my.package.jaxws_asm.MyMethod.arg0
            at my.package.jaxws_asm.MyMethod2
at com.sun.xml.bind.v2.runtime.IllegalAnnotationsException$Builder.check(IllegalAnnotationsException.java:102)
at com.sun.xml.bind.v2.runtime.JAXBContextImpl.getTypeInfoSet(JAXBContextImpl.java:472)
at com.sun.xml.bind.v2.runtime.JAXBContextImpl.<init>(JAXBContextImpl.java:302)
at com.sun.xml.bind.v2.runtime.JAXBContextImpl$JAXBContextBuilder.build(JAXBContextImpl.java:1140)
at com.sun.xml.bind.v2.ContextFactory.createContext(ContextFactory.java:154)
at com.sun.xml.bind.v2.ContextFactory.createContext(ContextFactory.java:121)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:616)
at javax.xml.bind.ContextFinder.newInstance(ContextFinder.java:222)
at javax.xml.bind.ContextFinder.find(ContextFinder.java:383)
at javax.xml.bind.JAXBContext.newInstance(JAXBContext.java:594)
at org.apache.cxf.jaxb.JAXBContextCache.createContext(JAXBContextCache.java:258)
at org.apache.cxf.jaxb.JAXBContextCache.getCachedContextAndSchemas(JAXBContextCache.java:167)
at org.apache.cxf.jaxb.JAXBDataBinding.createJAXBContextAndSchemas(JAXBDataBinding.java:418)
at org.apache.cxf.jaxb.JAXBDataBinding.initialize(JAXBDataBinding.java:290)
... 10 more

是否無法使用適配器來避免提供默認的無參數構造函數? 如果是,即使使用XmlJavaTypeAdapter注釋,有人也知道為什么我會得到異常?

將其更改為:


   @WebMethod
   public void myMethod(@XmlJavaTypeAdapter(ClassXAdapter.class)   ClassX arg0);

   @WebMethod
   @XmlJavaTypeAdapter(ClassXAdapter.class)
   public ClassX myMethod2();

需要在參數上定義適配器,而不是方法。

看看這個鏈接: http//weblogs.java.net/blog/kohsuke/archive/2005/09/using_jaxb_20s.html

這家伙幫我解決了很多jaxb問題。

像這樣:

public static void main(String[] args) throws Exception {
    JAXBContext context = JAXBContext.newInstance(Foo.class);
    StringWriter stringWriter = new StringWriter();
    context.createMarshaller().marshal(new Foo(new Bar(10)), stringWriter);
    System.out.println(stringWriter);
    Object o = context.createUnmarshaller().unmarshal(new StringReader(stringWriter.toString()));
    System.out.println(o);
}

@XmlRootElement
static class Foo {
    private Bar bar;
    Foo() {}
    Foo(Bar bar) { this.bar = bar; }
    @XmlJavaTypeAdapter(BarAdapter.class)
    public Bar getBar() { return bar; }
    public void setBar(Bar bar) { this.bar = bar; }
    public String toString() { return "Foo{bar=" + bar + '}'; }
}

static class Bar {
    private int x;
    Bar(int x) { this.x = x; }
    public int getX() { return x; }
    public void setX(int x) { this.x = x; }
    public String toString() { return "Bar{x=" + x + '}'; }
}

static class JaxbFriendlyBar {
    private int x;
    JaxbFriendlyBar() {}
    public int getX() { return x; }
    public void setX(int x) { this.x = x; }
}

static class BarAdapter extends XmlAdapter<JaxbFriendlyBar, Bar> {
    @Override
    public JaxbFriendlyBar marshal(Bar bar) throws Exception {
        JaxbFriendlyBar result = new JaxbFriendlyBar();
        result.setX(bar.getX());
        return result;
    }

    @Override
    public Bar unmarshal(JaxbFriendlyBar jaxbFriendlyBar) throws Exception {
        return new Bar(jaxbFriendlyBar.getX());
    }
}

或者只是添加一個no-arg默認構造函數:

Bar() {}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM