zl程序教程

您现在的位置是:首页 >  其他

当前栏目

JAXB使用方式详解编程语言

编程语言 使用 详解 方式
2023-06-13 09:20:35 时间

JAXB(Java Architecture for XML Binding) 是一个业界的标准,是一项可以根据XML Schema产生Java类的技术。该过程中,JAXB也提供了将XML实例文档反向生成Java对象树的方法,并能将Java对象树的内容重新写到 XML实例文档。

现在在软件开发中,主要也就是使用它XML与JAVA类互相转换的功能了

一些常用的属性解释:

Marshaller接口,将Java对象序列化为XML数据。
Unmarshaller接口,将XML数据反序列化为Java对象。

@XmlType,将Java类或枚举类型映射到XML模式类型
@XmlAccessorType(XmlAccessType.FIELD) ,控制字段或属性的序列化。FIELD表示JAXB将自动绑定Java类中的每个非静态的(static)、非瞬态的([email protected](标 注)字段到XML。其他值还有XmlAccessType.PROPERTY和XmlAccessType.NONE。
@XmlAccessorOrder,控制JAXB 绑定类中属性和字段的排序。
@XmlJavaTypeAdapter,使用定制的适配器(即扩展抽象类XmlAdapter并覆盖marshal()和unmarshal()方法),以序列化Java类为XML。
@XmlElementWrapper ,对于数组或集合(即包含多个元素的成员变量),生成一个包装该数组或集合的XML元素(称为包装器)。
@XmlRootElement,将Java类或枚举类型映射到XML元素。
@XmlElement,将Java类的一个属性映射到与属性同名的一个XML元素。
@XmlAttribute,将Java类的一个属性映射到与属性同名的一个XML属性。

 

下面是代码演示:

import java.io.Serializable; 

import javax.inject.Named; 

import javax.xml.bind.annotation.XmlAccessType; 

import javax.xml.bind.annotation.XmlAccessorType; 

import javax.xml.bind.annotation.XmlAttribute; 

import javax.xml.bind.annotation.XmlElement; 

import javax.xml.bind.annotation.XmlRootElement; 

import javax.xml.bind.annotation.XmlType; 

 * @XmlAccessorType(XmlAccessType.FIELD)指定映射本类的所有字段 

 * @XmlRootElement 用在class类的注解,[email protected],@XmlAccessorType一起使用.也可以单独使用,如果单独使用,[email protected] 

 * @XmlType,[email protected] 属性时,必须列出JavaBean对象中的所有XmlElement,否则会报错。 

 * @author smn 

@Named 

@XmlAccessorType(XmlAccessType.FIELD) 

@XmlRootElement(name = "Customer") 

@XmlType(name = "Customer", propOrder = { "age", "name" }) 

public class Customer implements Serializable { 

 private static final long serialVersionUID = 1L; 

 // [email protected]@[email protected],只会起到一个标识作用. 

 @XmlAttribute 

 int id; 

 @XmlElement 

 String name; 

 @XmlElement 

 int age; 

 public int getId() { 

 return id; 

 public void setId(int id) { 

 this.id = id; 

 public int getAge() { 

 return age; 

 public void setAge(int age) { 

 this.age = age; 

 public String getName() { 

 return name; 

 public void setName(String name) { 

 this.name = name; 

 }

JAVA转为XML

 public static void main(String[] args) { 

 Customer cus=new Customer(); 

 cus.setId(1); 

 cus.setName("Hello World!"); 

 cus.setAge(26); 

 try { 

 File file=new File("D://HelloWorld.xml"); 

 //初始化JAXBContext.JAXBContext类提供的JAXB API的客户端的入口点。 

 //它提供一个抽象的用于管理XML / Java绑定的必要信息,以实现JAXB绑定框架行动:解组,编组和验证。 

 JAXBContext jc=JAXBContext.newInstance(Customer.class); 

 //将Java对象Marshal成XML内容的Marshal的初始化设置. 

 Marshaller jaxbMarshaller=jc.createMarshaller(); 

 //output 

 jaxbMarshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true); 

 jaxbMarshaller.marshal(cus, file); 

 jaxbMarshaller.marshal(cus, System.out); 

 } catch (JAXBException e) { 

 System.out.println("output xml error!"); 

 e.printStackTrace(); 

 }

XML转为JAVA

 public static void main(String[] args) { 

 File file=new File("D://HelloWorld.xml"); 

 try { 

 //反着来 

 JAXBContext jc=JAXBContext.newInstance(Customer.class); 

 Unmarshaller unmarshaller=jc.createUnmarshaller(); 

 Customer cus=(Customer) unmarshaller.unmarshal(file); 

 System.out.println("data:"+cus); 

 System.out.println("data:"+cus.getId()); 

 System.out.println("data:"+cus.getName()); 

 System.out.println("data:"+cus.getAge()); 

 } catch (JAXBException e) { 

 System.out.println("input xml error!"); 

 e.printStackTrace(); 

 }

通常情况下就像上面的代码一样,转换后存储在本地,但这样并不能完成项目的实际应用,所以我们可以进行一下下面的优化

public static void main(String[] args) { 

 Customer cus=new Customer(); 

 cus.setId(1); 

 cus.setName("Hello World!"); 

 cus.setAge(26); 

 try { 

 //初始化JAXBContext.JAXBContext类提供的JAXB API的客户端的入口点。 

 //它提供一个抽象的用于管理XML / Java绑定的必要信息,以实现JAXB绑定框架行动:解组,编组和验证。 

 JAXBContext jc=JAXBContext.newInstance(Customer.class); 

 //将Java对象Marshal成XML内容的Marshal的初始化设置. 

 Marshaller jaxbMarshaller=jc.createMarshaller(); 

 StringWriter writer=new StringWriter(); 

 jaxbMarshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true); 

 jaxbMarshaller.marshal(cus, writer); 

 System.out.println(writer); 

 } catch (JAXBException e) { 

 System.out.println("output xml error!"); 

 e.printStackTrace(); 

 }

可以看到我们并不需要把XML存储到本地,可以在生成后直接将其转换为字符串,这样我们就可以通过dom4j、jdom等三方jar包对XML格式的字符串进行解析处理,如果把上面代码优化封装成一个泛型方法,就可以很方便的实现自动解析XML或者自动将实体类生成XML文件等操作。

当然生成XML文件的功能也很实用,比如制作一个自动生成数据库对象的生成工具。

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/11721.html

cjavaxml