将ArrayList中的对象序列化为XML时丢失类型元素

时间:2013-08-03 21:03:15

标签: xml-serialization jackson json-deserialization fasterxml

使用Jackson序列化为XML时,我似乎遇到了问题。我的代码如下:

TEST CONTAINER

package com.test;

import java.util.ArrayList;

import com.fasterxml.jackson.annotation.JsonProperty;

public class TestContainer {

    private String testContainerID;
    private String testContainerMessage;
    private ArrayList<TestChild> testContainerChildren;

    @JsonProperty("TestContainerID")
    public String getTestContainerID() {
        return testContainerID;
    }

    @JsonProperty("TestContainerID")
    public void setTestContainerID(String testContainerID) {
        this.testContainerID = testContainerID;
    }

    @JsonProperty("TestContainerMessage")
    public String getTestContainerMessage() {
        return testContainerMessage;
    }

    @JsonProperty("TestContainerMessage")
    public void setTestContainerMessage(String testContainerMessage) {
        this.testContainerMessage = testContainerMessage;
    }

    @JsonProperty("TestContainerChildren")
    public ArrayList<TestChild> getTestContainerChildren() {
        return testContainerChildren;
    }

    @JsonProperty("TestContainerChildren")
    public void setTestContainerChildren(ArrayList<TestChild> testContainerChildren) {
        this.testContainerChildren = testContainerChildren;
    }

}

TESTCHILD

package com.test;

import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonRootName;

@JsonRootName(value="TestChild")
public class TestChild {

    private String testChildID;
    private String testChildMessage;

    @JsonProperty("TestChildID")
    public String getTestChildID() {
        return testChildID;
    }

    @JsonProperty("TestChildID")
    public void setTestChildID(String testChildID) {
        this.testChildID = testChildID;
    }

    @JsonProperty("TestChildMessage")
    public String getTestChildMessage() {
        return testChildMessage;
    }

    @JsonProperty("TestChildMessage")
    public void setTestChildMessage(String testChildMessage) {
        this.testChildMessage = testChildMessage;
    }

}

使用

  • 序列化:

    XmlMapper xm = new XmlMapper(); TestContainer tc = xm.readValue(sb.toString(),TestContainer.class);

  • 反序列化:

    的System.out.println(xm.writeValueAsString(TC));   tc = xm.readValue(sb.toString(),TestContainer.class);

我正在做的是从类路径上的文件夹加载XML文件,并将文件的内容放入StringBuffer。问题是为对象集合生成的XML。在编写XML时,我想要类似的东西:

<TestContainerChildren><TestChild><...(Element Details)...></TestChild></TestContainerChildren>

但我得到了:

<TestContainerChildren><TestContainerChildren><...(Element Details)...><TestContainerChildren></TestContainerChildren>

我不确定我在这里缺少什么。我对序列化/反序列化的JSON部分没有问题,只有XML。我尝试使用Jackson和JAXB注释来关闭包装,我尝试使用以下注释:

  • @JsonRootName
  • @JsonProperty
  • @JacksonXmlElementWrapper
  • @JacksonElement
  • @XmlElementWrapper
  • @XmlElement

我很确定这对我来说是愚蠢的,但任何帮助都会非常感激。

2 个答案:

答案 0 :(得分:3)

我通过在变量声明上面使用以下注释来实现这一点:

  • @JacksonXmlElementWrapper(localName =“[insert collection name]”)
  • @JacksonXmlProperty(localName =“[insert collection element name”“)

这是一个简单的RTFM案例,因为它记录在案here

答案 1 :(得分:2)

好的,几个笔记。首先,@JsonRootName仅影响用于XML文档根的名称,顾名思义。所以它不用于TestChild。其次,听起来你想对列表使用所谓的“解包”输出,省略包含List元素的属性的元素。这可用于:

@JacksonXmlElementWrapper(useWrapping=false)
@JsonProperty("TestContainerChildren")
public ArrayList<TestChild> getTestContainerChildren() { ... }

因为默认设置是使用包装器(这与JAXB不同,默认情况下解包)。或者,如果您想全局更改此选项以假设已将其展开为默认值,则可以通过XmlModule更改默认值:

JacksonXmlModule module = new JacksonXmlModule();
// to default to using "unwrapped" Lists:
module.setDefaultUseWrapper(false);
XmlMapper xmlMapper = new XmlMapper(module);

希望这有帮助!