2012-12-04 21 views
5

Próbuję unmarshal pliku xml przy użyciu JAXB. Kiedy używam @XmlElement z poprawną nazwą i przestrzenią nazw, działa unmarshalling (np. @XmlElement (name = "name", namespace = "http://www.test.com"))Unmarshalling xml z JAXB - przestrzeń nazw z XmlType i proporder

Jeśli używam XmlType razem z propOrder niestety już nie jest (np. @XmlType (namespace = "http://www.test.com", name = "", propOrder = {"name", "description"})).

zawartość pliku XML (test.xml):

<Operation xmlns="http://www.test.com"> 
    <Parameter> 
    <name>Param1</name> 
    <description>Description of Parameter1</description> 
    </Parameter> 
    <Parameter> 
    <name>Param2</name> 
    <description>Description of Parameter2</description> 
    </Parameter> 
</Operation> 

Zawartość JAXBExample.java jest:

package stackoverflow.problem.jaxb.ns; 

import java.io.FileNotFoundException; 
import java.io.FileReader; 

import javax.xml.bind.JAXBContext; 
import javax.xml.bind.JAXBException; 
import javax.xml.bind.Unmarshaller; 

public class JAXBExample { 

    public static void main(String[] args) throws JAXBException, FileNotFoundException { 
    String xmlFilename = "test.xml"; 

    JAXBContext context = JAXBContext.newInstance(Operation.class); 

    System.out.println("Output from our XML File: "); 
    Unmarshaller um = context.createUnmarshaller(); 
    Operation op = (Operation) um.unmarshal(new FileReader(xmlFilename)); 

    System.out.println("Operation-Content: " + op); 
    } 

} 

Zawartość

pakietu stackoverflow.problem. jaxb.ns;

import java.util.List; 

import javax.xml.bind.annotation.XmlAccessType; 
import javax.xml.bind.annotation.XmlAccessorType; 
import javax.xml.bind.annotation.XmlElement; 
import javax.xml.bind.annotation.XmlRootElement; 


@XmlRootElement(name="Operation", namespace="http://www.test.com") 
@XmlAccessorType(XmlAccessType.FIELD) 

public class Operation { 

    @XmlElement(name = "Parameter", namespace="http://www.test.com") 
    List<Parameter> parameterList; 

    @Override 
    public String toString(){ 
    String retVal = ""; 
    for(Parameter currentParameter: parameterList){ 
     retVal += currentParameter.toString() + "\n"; 
    } 
    return retVal; 
    } 
} 

a zawartość Parameter.java jest:

package stackoverflow.problem.jaxb.ns; 

import javax.xml.bind.annotation.XmlAccessType; 
import javax.xml.bind.annotation.XmlAccessorType; 
import javax.xml.bind.annotation.XmlElement; 
import javax.xml.bind.annotation.XmlRootElement; 
import javax.xml.bind.annotation.XmlType; 

@XmlType(namespace="http://www.test.com", name = "", propOrder = {"name", "description"}) 
@XmlAccessorType(XmlAccessType.FIELD) 
public class Parameter { 

    //@XmlElement(name = "name", namespace="http://www.test.com") 
    String name; 

    //@XmlElement(name = "description", namespace="http://www.test.com") 
    String description; 

    @Override 
    public String toString(){ 
    return this.name + "\t" + this.description; 
    } 
} 

Gdybym odkomentowaniu dwie linie @XmlElement w ostatnim bloku kodu (Parameter.java), przy czym unmarshalling działa dobrze. Jeśli te dwie linie nie zostaną uwzględnione, oba pola w obiekcie Parameter mają wartość NULL. Czy istnieje inny sposób deklarowania przestrzeni nazw przy użyciu propOrder w XmlType? Czy zrobiłem coś złego?

Odpowiedz

5

Przestrzeń nazw może być także określona w opakowaniu, w pliku o nazwie package-info.java, w ten sposób nie trzeba powtarzać go w każdej klasie lub pola:

@javax.xml.bind.annotation.XmlSchema (
    namespace = "http://www.test.com", 
    elementFormDefault=javax.xml.bind.annotation.XmlNsForm.QUALIFIED 
) 
package stackoverflow.problem.jaxb.ns; 
+2

+1 - Aby uzyskać więcej informacji o JAXB i Przestrzenie nazw są widoczne na stronie: http://blog.bdoughan.com/2010/08/jaxb-namespaces.html –

+1

Wystarczy, aby to wskazać: nie tylko sprawia, że ​​kod jest mniej zagracony, ponieważ nie trzeba go umieszczać w każdym polu, a także rozwiązuje problem używania przestrzeni nazw w propOrder. – Exocom

Powiązane problemy