此上下文不知道替换组的类型或其任何子类

时间:2013-02-01 17:03:33

标签: xml jaxb xml-serialization jaxb2

对于从替换组生成的抽象超类,我似乎无法获得所有JAXB魔法。我正在使用JAXB的参考实现。

这是类层次结构:

+ DatasourceAbstract
  +----- DatasourceQuery
  +------DatasourceStatic

鉴于(如下所述)我已经明确地向JAXBContext提供了类和所有子类,对于我们为什么“未知”这一点我是一个谜。

如果需要更多信息,请与我们联系。我提供了我认为相关的所有内容,但不想超载帖子。

错误(为清晰起见,稍作编辑):

com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationsException: 1 counts of IllegalAnnotationExceptions
Invalid @XmlElementRef : Type "class com.escholar.reports.reportXML.DatasourceAbstract" or any of its subclasses are not known to this context.
this problem is related to the following location:
    at protected java.util.LinkedList com.escholar.reports.reportXML.Data.dataSourceSubstitutionGroupHead
    at com.escholar.reports.reportXML.Data
    at protected com.escholar.reports.reportXML.Data com.escholar.reports.reportXML.ReportJAXB.data
    at com.escholar.reports.reportXML.ReportJAXB
    at public com.escholar.reports.reportXML.ReportJAXB com.escholar.reports.reportXML.ObjectFactory.createReportResourceJAXB()
    at com.escholar.reports.reportXML.ObjectFactory

at com.sun.xml.internal.bind.v2.runtime.IllegalAnnotationsException$Builder.check(Unknown Source)
    .....  Partially ellided stacktrace ............
at javax.xml.bind.JAXBContext.newInstance(Unknown Source)
at com.escholar.reports.utilities.reportsamples.ReportXMLGenerator.main(ReportXMLGenerator.java:69)

JAXBContext Creation

这是我创建JAXB Context(触发上述异常的行)的地方:

JAXBContext jc = 
    JAXBContext.newInstance(
        com.escholar.reports.reportXML.ObjectFactory.class, 
        com.escholar.reports.reportXML.DatasourceAbstract.class, 
        com.escholar.reports.reportXML.DatasourceStatic.class, 
        com.escholar.reports.reportXML.DatasourceQuery.class);

DatasourceAbstract类

这是他们抱怨的课程。请注意,我还使用了@XmlSeeAlso来识别子类。

package com.escholar.reports.jaxb;

import javax.xml.bind.annotation.*;

@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "DatasourceAbstract")
@XmlSeeAlso({
    DatasourceStatic.class,
    DatasourceQuery.class
})
public abstract class DatasourceAbstract {

    @XmlAttribute(name = "Name")
    @XmlSchemaType(name = "anySimpleType")
    protected String name;

    public String getName() {
        return name;
    }

    public void setName(String value) {
        this.name = value;
    }
}

参考DatasourceAbstract

这里引用了DatasourceAbstract:

package com.escholar.reports.jaxb;

import java.util.ArrayList;
import java.util.List;
import javax.xml.bind.JAXBElement;
import javax.xml.bind.annotation.*;

@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {
    "dataSourceSubstitutionGroupHead"
})
@XmlRootElement(name = "Data")
public class Data {

    @XmlElementRef(name = "DataSourceSubstitutionGroupHead", type = JAXBElement.class)
    protected List<JAXBElement<?>> dataSourceSubstitutionGroupHead;

    public List<JAXBElement<?>> getDataSourceSubstitutionGroupHead() {
        if (dataSourceSubstitutionGroupHead == null) {
            dataSourceSubstitutionGroupHead = new ArrayList<JAXBElement<?>>();
        }
        return this.dataSourceSubstitutionGroupHead;
    }
}

2 个答案:

答案 0 :(得分:0)

在从XML模式生成的模型上创建JAXBContext时,您应该对生成的模型的包名称而不是单个类执行此操作。这将有助于确保JAXBContext拉入所有必要的课程。

JAXBContext jc = JAXBContext.newInstance("com.escholar.reports.reportXML");

答案 1 :(得分:0)

我遇到了同样的问题,所以我分享了我的解决方案:

@XmlSeeAlso()

由于子类的延迟加载,JAXB无法在正确的时间使用子类。

我的基本抽象类是FieldMapping,而继承的是FileFieldMapping和DatabaseFieldMapping(为简便起见,在此省略实现)。

@XmlRootElement(name = "fieldMapping")
@XmlSeeAlso({DatabaseFieldMapping.class, 
FileFieldMapping.class})
public abstract class FieldMapping {

}

@XmlRootElement(name = "fileFieldMapping")
public class FileFieldMapping extends FieldMapping {
}

@XmlRootElement(name = "databaseFieldMapping")
public class DatabaseFieldMapping extends 
FieldMapping 
{
}

您可以找到更多herehere