2010-09-14 5 views
5

Mam ENUM:JAXB + wyliczenia + Pokazuje wiele wartości

@XmlEnum 
@XmlRootElement 
public enum Product { 
    POKER("favourite-product-poker"), 
    SPORTSBOOK("favourite-product-casino"), 
    CASINO("favourite-product-sportsbook"), 
    SKILL_GAMES("favourite-product-skill-games"); 

    private static final String COULD_NOT_FIND_PRODUCT = "Could not find product: "; 

    private String key; 

    private Product(final String key) { 
     this.key = key; 
    } 

    /** 
    * @return the key 
    */ 
    public String getKey() { 
     return key; 
    } 

że wyjście w usłudze REST tak:

GenericEntity<List<Product>> genericEntity = new GenericEntity<List<Product>>(products) { 
}; 
return Response.ok().entity(genericEntity).build(); 

i wyprowadza tak:

<products> 
<product>POKER</product> 
<product>SPORTSBOOK</product> 
<product>CASINO</product> 
<product>SKILL_GAMES</product> 
</products> 

Chcę, aby był wyprowadzany z nazwą użytkownika (np. POKER) i kluczem (np. "Ulubiony produkt pokerowy").

Próbowałem różnych sposobów, w tym przy użyciu @ XmlElement, @XmlEnumValue i @XmlJavaTypeAdapter, bez uzyskiwania obu na raz w tym samym czasie.

Czy ktoś wie, jak to osiągnąć, tak jak w przypadku normalnej fasoli z adnotacjami JAXB?

Dzięki.

Odpowiedz

4

Można utworzyć obiekt otoki dla tego, coś jak:

import javax.xml.bind.annotation.XmlAttribute; 
import javax.xml.bind.annotation.XmlRootElement; 
import javax.xml.bind.annotation.XmlValue; 

@XmlRootElement(name="product") 
public class ProductWrapper { 

    private Product product; 

    @XmlValue 
    public Product getValue() { 
     return product; 
    } 

    public void setValue(Product value) { 
     this.product = value; 
    } 

    @XmlAttribute 
    public String getKey() { 
     return product.getKey(); 
    } 

} 

będzie to odpowiadać następującym XML:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?> 
<product key="favourite-product-poker">POKER</product> 

Ty musiałby przejść wystąpień ProductWrapper do JAXB zamiast Produkt.

import javax.xml.bind.JAXBContext; 
import javax.xml.bind.Marshaller; 

public class Demo { 

    public static void main(String[] args) throws Exception { 
     JAXBContext jc = JAXBContext.newInstance(ProductWrapper.class); 

     ProductWrapper pw = new ProductWrapper(); 
     pw.setValue(Product.POKER); 

     Marshaller marshaller = jc.createMarshaller(); 
     marshaller.marshal(pw, System.out); 
    } 

} 
-1

Musisz usunąć wartość @XmlEnum z wartości wyliczeniowej, jeśli chcesz, aby była serializowana do formatu XML jak normalny obiekt. Wyliczenie (z definicji) jest reprezentowane w XML przez pojedynczy symbol ciągu. Pozwala to na przykład połączyć je z @XmlList, aby utworzyć skuteczną listę elementów oddzielonych spacjami.

2

można użyć adaptera:

import java.io.StringWriter; 
import java.util.ArrayList; 
import java.util.List; 

import javax.xml.bind.JAXBContext; 
import javax.xml.bind.Marshaller; 
import javax.xml.bind.annotation.XmlAttribute; 
import javax.xml.bind.annotation.XmlElement; 
import javax.xml.bind.annotation.XmlElementWrapper; 
import javax.xml.bind.annotation.XmlRootElement; 
import javax.xml.bind.annotation.XmlSeeAlso; 
import javax.xml.bind.annotation.XmlType; 
import javax.xml.bind.annotation.XmlValue; 
import javax.xml.bind.annotation.adapters.XmlAdapter; 
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter; 

public class XmlEnumTest{ 

    public static void main(String...str) throws Exception{ 
     JAXBContext jc = JAXBContext.newInstance(ProductList.class); 
     StringWriter sw = new StringWriter(); 
     Marshaller marshaller = jc.createMarshaller(); 
     marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true); 
     marshaller.marshal(new ProductList(),sw); 
     System.out.println(sw.toString()); 
    } 
} 

class ProductTypeAdaper extends XmlAdapter<ProductAdapter, Product> { 
    @Override 
    public Product unmarshal(ProductAdapter v) throws Exception { 
     return Product.valueOf(v.value); 
    } 

    @Override 
    public ProductAdapter marshal(Product v) throws Exception { 
     ProductAdapter result = new ProductAdapter(); 
     result.key = v.getKey(); 
     result.value = v.name(); 
     return result; 
    } 
} 

@XmlType 
class ProductAdapter{ 
    @XmlAttribute 
    public String key; 
    @XmlValue 
    public String value; 
} 

@XmlJavaTypeAdapter(ProductTypeAdaper.class) 
enum Product{ 
    POKER("favourite-product-poker"), 
    SPORTSBOOK("favourite-product-casino"), 
    CASINO("favourite-product-sportsbook"), 
    SKILL_GAMES("favourite-product-skill-games"); 

    private static final String COULD_NOT_FIND_PRODUCT = "Could not find product: "; 

    private String key; 

    private Product(final String key) { 
     this.key = key; 
    } 

    /** 
    * @return the key 
    */ 
    public String getKey() { 
     return key; 
    } 

} 

@XmlRootElement 
@XmlSeeAlso({Product.class}) 
class ProductList{ 
    @XmlElementWrapper(name="products") 
    @XmlElement(name="product") 
    private List<Product> list = new ArrayList<Product>(){{add(Product.POKER);add(Product.SPORTSBOOK);add(Product.CASINO);}}; 
}