2014-11-21 97 views
1

我试图从JAXB RI 2.2.7切换到MOXy JAXB 2.5.2实现。 我注意到在生成的XML输出片段中的命名空间和前缀以下区别:MOXy创建比JAXB不同的命名空间前缀RI

JAXB RI:

<xbrli:xbrl xmlns:xbrli="http://www.xbrl.org/2003/instance" xmlns:bd-algemeen="http://www.nltaxonomie.nl/7.0/basis/bd/items/bd-algemeen" xmlns:iso4217="http://www.xbrl.org/2003/iso4217"> 
    <bd-algemeen:OperatingSystem contextRef="cc_131">W</bd-algemeen:OperatingSystem> 
    <xbrli:unit id="uu_692"> 
     <xbrli:measure>iso4217:EUR</xbrli:measure> 
    </xbrli:unit> 
</xbrli:xbrl> 

莫西:

<xbrli:xbrl xmlns:xbrli="http://www.xbrl.org/2003/instance" xmlns:bd-algemeen="http://www.nltaxonomie.nl/7.0/basis/bd/items/bd-algemeen"> 
    <bd-algemeen:OperatingSystem contextRef="cc_131">W</bd-algemeen:OperatingSystem> 
    <xbrli:unit id="uu_662"> 
    <xbrli:measure xmlns:ns0="http://www.xbrl.org/2003/iso4217">ns0:EUR</xbrli:measure> 
    </xbrli:unit> 
</xbrli:xbrl> 

1)如何配置MOXy输出相同的RI? MOXy输出有效,但我创建的XML(实际上是XBRL)文档必须具有预定义的前缀。

2)我使用“com.sun.xml.bind.marshaller.NamespacePrefixMapper”的实例来指示应该使用的前缀。然而,MOXy在iso4217命名空间中不会调用这个,为什么(我调试了MOXy命名空间解析器但有点丢失了)? BTW:Moxy使用prefixMapper作为其他命名空间(比如“xbrli”),但不是这个iso4217,有什么区别?

我添加了“bd-algemeen”,因为前缀映射器被称为前缀“bd-algemeen”。该映射不使用iso4217所使用的QName。 3)我在生成的iso4217封装中的pacakage-info.java中尝试@XmlSchema注释来定义前缀,但没有运气,我也不想使用它,因为它涉及容易覆盖的生成代码。

域对象:

@XmlAccessorType(XmlAccessType.FIELD) 
@XmlType(name = "", propOrder = { "divide", "measures" }) 
@XmlRootElement(name = "unit") 
public class Unit { 
    protected Divide divide; 

    @XmlElement(name = "measure") 
    protected List<QName> measures; 
} 

@XmlAccessorType(XmlAccessType.FIELD) 
@XmlType(name = "", propOrder = { "operatingSystem"}) 
public static class TaxDataBedrijf { 

    @XmlElement(name = "OperatingSystem", namespace = "http://www.nltaxonomie.nl/7.0/basis/bd/items/bd-algemeen") 
    protected Astring1ItemType operatingSystem; 

该股实例的创建:

final Unit item = new Unit(); 
item.getMeasures().add(new QName("http://www.xbrl.org/2003/iso4217", "EUR", "iso4217")); 

taxData = new TaxDataBedrijf(); 
taxData.setOperatingSystem(createOperatingSystem(context, 'W')); 

我想这可能是因为的QName使用的,但这也是直接在其他地方使用并正确使用。例如,莫西能够生成这个片段:

<xbrli:xbrl xmlns:xbrli="http://www.xbrl.org/2003/instance" xmlns:bd-domains="http://www.nltaxonomie.nl/7.0/basis/bd/domains/bd-domains" xmlns:bd-axes="http://www.nltaxonomie.nl/7.0/domein/bd/axes/bd-axes"> 
    <xbrli:scenario> 
    <xbrldi:explicitMember dimension="bd-axes:TimeDimension">bd-domains:Current</xbrldi:explicitMember> 
    </xbrli:scenario> 
</xbrli:xbrl> 

以及相应的Java绑定:

@XmlAccessorType(XmlAccessType.FIELD) 
@XmlType(name = "", propOrder = { "value" }) 
@XmlRootElement(name = "explicitMember") 
public class ExplicitMember { 

    @XmlValue 
    protected QName value; 

    @XmlAttribute(name = "dimension") 
    protected QName dimension; 
} 

它的创作:

final ExplicitMember item = new ExplicitMember(); 
item.setDimension(new QName("http://www.nltaxonomie.nl/7.0/domein/bd/axes/bd-axes", "TimeDimension")); 
item.setValue(new QName("http://www.nltaxonomie.nl/7.0/basis/bd/domains/bd-domains", "Current")); 

请一些建议。如何解决这个问题,以便我可以使用MOXY而不是RI(在Moxy代码中查找的地方也许?)。

+0

其中的EclipseLink莫西的版本您使用的? – 2014-11-21 18:43:43

+0

对不起,我忘记了,只是添加了它(RI:2.2.7; Moxy:2.5.2) – edbras 2014-11-21 18:46:31

+0

MOXy根本没有击中'NamespacePrefixMapper',还是击中了所有元素,但不是合格的文本值? – 2014-11-21 18:53:49

回答

0

我得到了它与正确的名称空间符号的工作,也就是说,它产生:

<xbrli:unit id="uu_382"> 
    <xbrli:measure>iso4217:EUR</xbrli:measure> 
</xbrli:unit> 

我花了一些(很多)的时间调试莫西代码和比较被正确使用的命名空间和发现上述代码片段的ObjectFactory不包含任何@XmlElementDecl注释,就像那些正在工作的注解。当加入这一点,它的工作原理,即:

private static final QName EUR_QNAME = new QName("http://www.xbrl.org/2003/iso4217", "EUR", "iso4217"); 

@XmlElementDecl(namespace = "http://www.xbrl.org/2003/iso4217", name = "EUR", substitutionHeadNamespace = "http://www.xbrl.org/2003/instance", substitutionHeadName = "item") 
public JAXBElement<EUR> createEURO() { 
    return new JAXBElement<EUR>(EUR_QNAME, EUR.class, null, createEUR()); 
} 

我注意到,在创建XBRL(根标签)映射时,它会遍历属性,这些属性之一是属性“itemsAndTuplesAndContexts”。然后它通过关联的引用元素(Moxy代码:MappingGenerator.generateMappingForReferenceProperty(..))进行循环,并将它们添加到其名称空间解析器映射中,并生成前缀,该映射存储在它的描述符中。 编组期间,它将使用前缀映射器来映射其存储的名称空间。因为我为iso4217元素添加了@XmlElementDecl声明,所以它找到了一个引用元素,因此它被添加到Xbrl根元素的名称空间解析器映射中,并在编组期间在前缀映射器中使用。

有几个问题我没有很明确:

  1. 为什么莫西需要此@XmlElementDecl,而不是由JAXB RI?
  2. 为什么在使用XJC生成代码期间不会生成这个@XmlElementDecl元素?
  3. @Blaise:你认为这是一个错误?

财产 “itemsAndTuplesAndContexts” 声明:

@XmlElementRefs({ @XmlElementRef(name = "unit", namespace = "http://www.xbrl.org/2003/instance", type = Unit.class), 
    @XmlElementRef(name = "context", namespace = "http://www.xbrl.org/2003/instance", type = Context.class), 
    @XmlElementRef(name = "item", namespace = "http://www.xbrl.org/2003/instance", type = JAXBElement.class), 
    @XmlElementRef(name = "tuple", namespace = "http://www.xbrl.org/2003/instance", type = JAXBElement.class), 
    @XmlElementRef(name = "footnoteLink", namespace = "http://www.xbrl.org/2003/linkbase", type = JAXBElement.class) }) 
    protected List<Object> itemsAndTuplesAndContexts; 
1

您所看到的行为是一个错误,我已经打开了下面的问题吧:

+0

Wowwww,我知道你很快......但这很快;)...我只是增加了一些更多的工作场景...谢谢,我直到监视bug ...任何想法,直到它解决了(一周,几个月,..)? 解决方法? 我可以提供更多调试信息吗? – edbras 2014-11-21 19:49:40

+0

请将您对我在此主题中答案的反馈意见发送给我? – edbras 2014-11-23 13:04:03