Znalazłem kilka przykładów JAXB2 @XmlRegistry
przez Internet, ale brak dobrych dogłębnych samouczków, które mówią o koncepcji używania @XmlRegistry
z @XmlElementDecl
, zastanawiam się, czy jest to pojęcie mało zbadane w ogóle.@XmlRegistry - jak to działa?
Anyways tutaj jest moje pytanie, pierwsze kilka klas przykładowe że używam aby wycofać xml przy użyciu JAXB:
Główna klasa Próbuję unmarshal użyciu JAXB - Employee.java
package com.test.jaxb;
import java.util.List;
import javax.xml.bind.JAXBElement;
import javax.xml.bind.annotation.XmlElementDecl;
import javax.xml.bind.annotation.XmlRegistry;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.namespace.QName;
import com.test.jaxb.dto.Address;
@XmlRootElement
public class Employee {
private int id;
private String name;
private String email;
private List<Address> addresses;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public List<Address> getAddresses() {
return addresses;
}
public void setAddresses(List<Address> addresses) {
this.addresses = addresses;
}
@SuppressWarnings("unused")
@XmlRegistry
public static class XMLObjectFactory {
@XmlElementDecl(scope = Employee.class, name= "id")
JAXBElement<String> createEmployeeId(String value) {
return new JAXBElement<String>(new QName("id"), String.class, "100");
}
@XmlElementDecl(scope = Employee.class, name= "name")
JAXBElement<String> createName(String value) {
return new JAXBElement<String>(new QName("name"), String.class, "Fake Name");
}
@XmlElementDecl(scope = Employee.class, name= "email")
JAXBElement<String> createEmail(String value) {
return new JAXBElement<String>(new QName("email"), String.class, value);
}
@XmlElementDecl(scope = Employee.class, name= "addresses")
JAXBElement<List> createAddresses(List value) {
return new JAXBElement<List>(new QName("addresses"), List.class, value);
}
}
}
Klasa dziecko - Address.java
package com.test.jaxb.dto;
import javax.xml.bind.JAXBElement;
import javax.xml.bind.annotation.XmlElementDecl;
import javax.xml.bind.annotation.XmlRegistry;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.namespace.QName;
import com.test.jaxb.Employee;
@XmlRootElement
public class Address {
private String addressLine1;
private String addressLine2;
private String addressLine3;
public String getAddressLine1() {
return addressLine1;
}
public void setAddressLine1(String addressLine1) {
this.addressLine1 = addressLine1;
}
public String getAddressLine2() {
return addressLine2;
}
public void setAddressLine2(String addressLine2) {
this.addressLine2 = addressLine2;
}
public String getAddressLine3() {
return addressLine3;
}
public void setAddressLine3(String addressLine3) {
this.addressLine3 = addressLine3;
}
@SuppressWarnings("unused")
@XmlRegistry
private static class XMLObjectFactory {
@XmlElementDecl(scope = Employee.class, name= "addressLine1")
JAXBElement<String> createAddressLine1(String value) {
return new JAXBElement<String>(new QName("addressLine1"), String.class, value);
}
@XmlElementDecl(scope = Employee.class, name= "addressLine2")
JAXBElement<String> createAddressLine2(String value) {
return new JAXBElement<String>(new QName("addressLine2"), String.class, value);
}
@XmlElementDecl(scope = Employee.class, name= "addressLine3")
JAXBElement<String> createAddressLine3(String value) {
return new JAXBElement<String>(new QName("addressLine3"), String.class, value);
}
}
}
xml być unmarshalled - employee.xml
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<employee>
<id>1</id>
<name>Vaishali</name>
<email>[email protected]</email>
<addresses>
<address>
<addressLine1>300</addressLine1>
<addressLine2>Mumbai</addressLine2>
<addressLine3>India</addressLine3>
</address>
<address>
<addressLine1>301</addressLine1>
<addressLine2>Pune</addressLine2>
<addressLine3>India</addressLine3>
</address>
</addresses>
</employee>
Kod Unmarshalling:
package com.test.jaxb;
import java.io.FileReader;
import javax.xml.bind.JAXBContext;
import javax.xml.bind.Unmarshaller;
public class ObjectFactoryTest {
public static void main(String[] args) throws Exception {
FileReader reader = new FileReader("resources/employee.xml");
JAXBContext context = JAXBContext.newInstance(Employee.class);
Unmarshaller unmarshaller = context.createUnmarshaller();
Object obj = unmarshaller.unmarshal(reader);
System.out.println(obj);
}
}
Kiedy unmarshal xml pracowników przy użyciu powyżej kodu, lista adresów nie uzyskać zaludnionych. Wynikowy obiekt pracownika ma tylko pustą listę adresów. Czy coś jest nie tak z moimi mapowaniami?
Aby dowiedzieć się, co się dzieje i zobaczyć, czy obiekty pracowników są rzeczywiście tworzone przy użyciu Fabryki obiektów (z adnotacją @XMLRegistry), zmieniłem wartość identyfikatora i nazwy w metodach fabrycznych, jednak nie miało to żadnego skutku na wyjściu, które mówi mi, że JAXB nie używa w rzeczywistości ObjectFactory, dlaczego?
Czy wszystko się zgadza? Każda pomoc będzie doceniona.
Znalazłem kilka przykładów "@XmlRegistry" użytych w taki sam sposób, w jaki ja go używam, patrz [tutaj] (http://www.codezealot.org/archives/5). Rozumiem, że mogę użyć "@XmlElementWrapper", aby to zrobić. Moje pytanie dotyczyło raczej zrozumienia, czym jest "@XmlRegistry" i co mogę z tym zrobić. AFAIK Powinienem móc użyć obiektu objectfactory (opatrzonego adnotacją "@XmlRegistry") do niepoprawnego zapisu xml i przekształcenia go w obiekt. Jeśli nie, to do czego służy? Czy muszę go gdzieś zarejestrować, aby został użyty (jak pokazałem na moim przykładzie, moja fabryka obiektów nigdy nie jest tak naprawdę używana przez JAXB)? – gresdiplitude
Moje rozumienie może być tutaj całkowicie błędne, ale pomyślałem, że musi istnieć sposób zastosowania czegoś podobnego do "@XmlElementWrapper" do "@XmlRegistry", ponieważ jest to alternatywny sposób eliminowania XML. Brak punktów za zgadywanie Jestem całkowicie zdezorientowany, jak działa @XmlRegistry !!! – gresdiplitude
@Vaishali - zaktualizowałem swoją odpowiedź, dodając przykład wykorzystujący "@ XmlRegistry' i' @ XmlElementDecl' –