Интернет програмиране с JAVA
JAXB осигурява бърз и удобен начин за обвързване на XML схеми и Java представителства, като улеснява разработчиците на Java да включват XML данни и функции за обработка в Java приложения. Като част от този процес, JAXB предоставя методи за демаркиране (четене) на документи от XML екземпляри в дървета със съдържание на Java и след това преобразуване (писане) на дървета със съдържание на Java обратно в документи на XML инстанции. JAXB предоставя също начин за генериране на XML схема от Java обекти.
Annotation | Description |
---|---|
@XmlRootElement(namespace = “namespace”) | Дефинирайте коренния елемент за XML дърво |
@XmlType(propOrder = { “field2”, “field1”,.. }) | Позволява да се определи редът, в който полетата се записват във XML файла |
@XmlElement(name = “neuName”) | Определете XML елемента, който ще бъде използван. Трябва да се използва само ако името на XML елемента е различен от името на JavaBeans |
<dependency>
<groupId>javax.xml.bind</groupId>
<artifactId>jaxb-api</artifactId>
<version>2.2.8</version>
</dependency>
<!--ЗА РАБОТА С JAXB от JAVA 9 нагоре-->
<dependency>
<groupId>org.glassfish.jaxb</groupId>
<artifactId>jaxb-runtime</artifactId>
<version>2.3.1</version>
</dependency>
@XmlRootElement(name = "student")
@XmlAccessorType(XmlAccessType.FIELD)
// Не е задължително но ако искате, можете да определите реда, в който да се запишат полетата
@XmlType(propOrder = { "fakNum", "name", "specialty")
public class Student {
private String name;
//Ако името на променливата не е подходящо за записване в XML файл, можете лесно да се промените
@XmlElement(name = "fakNum")
private String number;
private String specialty;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getNumber() {
return number;
}
public void setNumber(String number) {
this.number = number;
}
public String getSpecialty() {
return specialty;
}
public void setSpecialty(String specialty) {
this.specialty = specialty;
}
}
//Тази анотация означава, че клас "Group.java" е основният елемент на файла
@XmlRootElement(name = "group")
@XmlAccessorType(XmlAccessType.FIELD)
public class Group {
// XmLElementWrapper генерира обвиващ елемент около XML елементите, родителския елемент
@XmlElementWrapper(name = "studentList")
// XmlElement задава името на вътрешните елементи
@XmlElement(name = "student")
private ArrayList<Student> students;
private int number;
private String department;
public void setStudents(ArrayList<Student> students) {
this.students = students;
}
public ArrayList<Student> getStudents() {
return students;
}
public String getNumber() {
return number;
}
public void setNumber(String number) {
this.number = number;
}
public String getDepartment() {
return department;
}
public void setDepartment(String department) {
this.department = department;
}
}
public void writeToXMLFile(String xmlFile, Group group) {
// Създаване на JAXB контекст
JAXBContext context = JAXBContext.newInstance(Group.class);
// Създаване на marshaller инстанция
Marshaller m = context.createMarshaller();
m.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE);
// Записване в System.out
m.marshal(group, System.out);
// Записване във файл
m.marshal(group, new File(xmlFile));
}
public Group readerFromXMLFile(String xmlFile) {
// Създаване на JAXB контекст
JAXBContext context = JAXBContext.newInstance(Group.class);
// Създаване на unmarshaller инстанция
Unmarshaller um = context.createUnmarshaller();
Group group = (Group) um.unmarshal(new FileReader(xmlFile));
return group
}