Элементы сопоставления JAXB с «неизвестным» именем - PullRequest
4 голосов
/ 25 ноября 2010

У меня есть XML, который вне моего контроля над тем, как он генерируется.Я хочу создать из него объект, демаршируя его в класс, написанный мной вручную.

Один фрагмент его структуры выглядит так:

<categories>
    <key_0>aaa</key_0>
    <key_1>bbb</key_1>
    <key_2>ccc</key_2>
</categories>

Как я могу обрабатывать такие случаи?Конечно, количество элементов является переменным.

Ответы [ 3 ]

5 голосов
/ 25 ноября 2010

Если вы используете следующую объектную модель, то каждый из неотображенных элементов key_ # будет сохранен как экземпляр org.w3c.dom.Element:

import java.util.List;
import javax.xml.bind.annotation.XmlAnyElement;
import javax.xml.bind.annotation.XmlRootElement;
import org.w3c.dom.Element;

@XmlRootElement
public class Categories {

    private List<Element> keys;

    @XmlAnyElement
    public List<Element> getKeys() {
        return keys;
    }

    public void setKeys(List<Element> keys) {
        this.keys = keys;
    }

}

Если какой-либо из элементов соответствует классамсопоставленный с аннотацией @XmlRootElement, вы можете использовать @XmlAnyElement (lax = true), и известные элементы будут преобразованы в соответствующие объекты.Для примера см .:

0 голосов
/ 22 июня 2015

Используйте вот так

        @XmlRootElement
        @XmlAccessorType(XmlAccessType.FIELD)
        public static class Categories {


            @XmlAnyElement
            @XmlJavaTypeAdapter(ValueAdapter.class)
            protected List<String> categories=new ArrayList<String>();

            public List<String> getCategories() {
                return categories;
            }
            public void setCategories(String value) {
                this.categories.add(value);
            }
        }

        class ValueAdapter extends XmlAdapter<Object, String>{

           @Override
           public Object marshal(String v) throws Exception {
              // write code for marshall
             return null;
           }

           @Override
           public String unmarshal(Object v) throws Exception {
              Element element = (Element) v;
              return element.getTextContent();
          }
       }
0 голосов
/ 25 ноября 2010

Для этого простого элемента я бы создал класс с именем Categories:

import javax.xml.bind.annotation.XmlRootElement;

@XmlRootElement
public class Categories {

    protected String key_0;
    protected String key_1;
    protected String key_2;

    public String getKey_0() {
        return key_0;
    }

    public void setKey_0(String key_0) {
        this.key_0 = key_0;
    }

    public String getKey_1() {
        return key_1;
    }

    public void setKey_1(String key_1) {
        this.key_1 = key_1;
    }

    public String getKey_2() {
        return key_2;
    }

    public void setKey_2(String key_2) {
        this.key_2 = key_2;
    }

}

Затем в основном методе я бы создал unmarshaller:

JAXBContext context = JAXBContext.newInstance(Categories.class);
Unmarshaller um = context.createUnmarshaller();
Categories response = (Categories) um.unmarshal(new FileReader("my.xml"));
// access the Categories object "response"

Toбыть в состоянии получить все объекты, я думаю, я бы поместил все элементы в корневой элемент в новый XML-файл и написал класс для этого корневого элемента с аннотацией @XmlRootElement.

Надеюсь, это поможет, мман1010 *

...