как преодолеть проблему «java.sql.Clob - это интерфейс, а JAXB не может обрабатывать интерфейсы» - PullRequest
2 голосов
/ 04 июня 2011

Я делаю jaxbcontext newInstance, передавая DO как класс. Мой DO содержит java.sql.clob в качестве одного из полей. Это поле clob создает проблему при создании нового экземпляра. Давать ошибку как Исключение произошло во время захвата clob

com.sun.xml.bind.v2.runtime.IllegalAnnotationsException: 3 counts of IllegalAnnotationExceptions
java.sql.Clob is an interface, and JAXB can't handle interfaces.
    this problem is related to the following location:
        at java.sql.Clob
        at public java.sql.Clob com.data.subscriber.SubscriberProvTransDO.getXmlString()
        at com.data.subscriber.SubscriberProvTransDO
The type of the getter is java.io.InputStream but that of the setter is long. They have to be the same.
    this problem is related to the following location:
        at public abstract java.io.InputStream java.sql.Clob.getAsciiStream() throws java.sql.SQLException
        at java.sql.Clob
        at public java.sql.Clob com.data.subscriber.SubscriberProvTransDO.getXmlString()
        at com.data.subscriber.SubscriberProvTransDO
    this problem is related to the following location:
        at public abstract java.io.OutputStream java.sql.Clob.setAsciiStream(long) throws java.sql.SQLException
        at java.sql.Clob
        at public java.sql.Clob com.data.subscriber.SubscriberProvTransDO.getXmlString()
        at com.data.subscriber.SubscriberProvTransDO
The type of the getter is java.io.Reader but that of the setter is long. They have to be the same.
    this problem is related to the following location:
        at public abstract java.io.Reader java.sql.Clob.getCharacterStream() throws java.sql.SQLException
        at java.sql.Clob
        at public java.sql.Clob com.data.subscriber.SubscriberProvTransDO.getXmlString()
        at com.data.subscriber.SubscriberProvTransDO
    this problem is related to the following location:
        at public abstract java.io.Writer java.sql.Clob.setCharacterStream(long) throws java.sql.SQLException
        at java.sql.Clob
        at public java.sql.Clob com.data.subscriber.SubscriberProvTransDO.getXmlString()
        at com.data.subscriber.SubscriberProvTransDO

    at com.sun.xml.bind.v2.runtime.IllegalAnnotationsException$Builder.check(IllegalAnnotationsException.java:66)
    at com.sun.xml.bind.v2.runtime.JAXBContextImpl.getTypeInfoSet(JAXBContextImpl.java:389)
    at com.sun.xml.bind.v2.runtime.JAXBContextImpl.<init>(JAXBContextImpl.java:236)
    at com.sun.xml.bind.v2.ContextFactory.createContext(ContextFactory.java:76)
    at com.sun.xml.bind.v2.ContextFactory.createContext(ContextFactory.java:55)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:79)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:618)
    at javax.xml.bind.ContextFinder.newInstance(ContextFinder.java:210)
    at javax.xml.bind.ContextFinder.find(ContextFinder.java:368)
    at javax.xml.bind.JAXBContext.newInstance(JAXBContext.java:574)
    at javax.xml.bind.JAXBContext.newInstance(JAXBContext.java:522)
    at com.business.system.handler.EventProcessorHandler.insertFailure(EventProcessorHandler.java:286)
    at com.business.system.handler.EventProcessorHandler.processRequest(EventProcessorHandler.java:184)
    at com.business.system.EventProcessorBean.onMessage(EventProcessorBean.java:51)
    at com.ibm.ejs.container.MessageEndpointHandler.invokeMdbMethod(MessageEndpointHandler.java:1086)
    at com.ibm.ejs.container.MessageEndpointHandler.invoke(MessageEndpointHandler.java:773)
    at $Proxy6.onMessage(Unknown Source)
    at com.ibm.ws.sib.api.jmsra.impl.JmsJcaEndpointInvokerImpl.invokeEndpoint(JmsJcaEndpointInvokerImpl.java:201)
    at com.ibm.ws.sib.ra.inbound.impl.SibRaDispatcher.dispatch(SibRaDispatcher.java:768)
    at com.ibm.ws.sib.ra.inbound.impl.SibRaSingleProcessListener$SibRaWork.run(SibRaSingleProcessListener.java:584)
    at com.ibm.ejs.j2c.work.WorkProxy.run(WorkProxy.java:419)
    at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1469)

1 Ответ

3 голосов
/ 06 июня 2011

Вы можете использовать XmlAdapter для этого варианта использования. Адаптер XML преобразует не отображаемый объект java.sql.Clob в отображаемый объект, например String:

ClobAdapter

import java.sql.Clob;

import javax.xml.bind.annotation.adapters.XmlAdapter;

public class ClobAdapter extends XmlAdapter<String, Clob> {

    @Override
    public Clob unmarshal(String v) throws Exception {
        // Convert String to Clob
    }

    @Override
    public String marshal(Clob v) throws Exception {
        // Convert Clob to String
    }

}

Root

@XmlJavaTypeAdapter должно быть установлено в свойстве Clob. Эта аннотация, как вы ссылаетесь в XmlAdapter:

import java.sql.Clob;

import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;

public class Root {

    private Clob clob;

    @XmlJavaTypeAdapter(ClobAdapter.class)
    public Clob getClob() {
        return clob;
    }

    public void setClob(Clob clob) {
        this.clob = clob;
    }

}

Демо

import javax.xml.bind.JAXBContext;

public class Demo {

    public static void main(String[] args) throws Exception {
        JAXBContext jc = JAXBContext.newInstance(Root.class);
    }
}

Для получения дополнительной информации

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...