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)、非瞬态的(由@XmlTransient(标
注)字段到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类的注解,常与@XmlRootElement,@XmlAccessorType一起使用.也可以单独使用,如果单独使用,需要在get方法上加@XmlElement等注解.
* @XmlType,在使用@XmlType的propOrder 属性时,必须列出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; // 其实@XmlType已经默认会读取下面的name和age.@XmlElement在@XmlType存在的情况下,只会起到一个标识作用.
@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文件的功能也很实用,比如制作一个自动生成数据库对象的生成工具。

最新文章

  1. 浏览器请求URL原理
  2. javascript运算符——条件、逗号、赋值、()和void运算符
  3. scala言语基础学习五
  4. SQL Server中查询结果拼接遇到的小问题
  5. 【iOS】iOS消息推送机制的实现
  6. 前端笔试题 JS部分
  7. VS插件-JSEnhancements
  8. MySQL导出csv乱码问题的解决
  9. redis 字典
  10. Oracle 体系结构chapter2
  11. Django连接oracle数据库的那些问题
  12. 2018-2019-2 20165312《网络攻防技术》Exp3 免杀原理与实践
  13. OPTIMIZER_INDEX_COST_ADJ 与OPTIMIZER_INDEX_CACHING 参数说明
  14. Alpha阶段敏捷冲刺(二)
  15. wxWidgets与其他工具库的比较(上)
  16. PL/SQL之包
  17. [COGS 2066]七十和十七
  18. 20155315庄艺霖第三次作业之Linux初体验
  19. 【插头DP】BZOJ3125-city
  20. Vue指令(四)--v-model

热门文章

  1. 2 3 5 7的倍数 (51Nod - 1284)[容斥定理]
  2. 清除input框的缓存
  3. [NodeJs系列][译]理解NodeJs中的Event Loop、Timers以及process.nextTick()
  4. 关于Ext.js和Ext.Net的杂谈
  5. ethereum(以太坊)(基础)--容易忽略的坑(三)
  6. 微信小程序关于tabbar点击切换数据不刷新问题
  7. 【php】php 生僻知识点认知
  8. python -pickle模块、re模块学习
  9. node 分层开发
  10. HDU暑假多校第四场J-Let Sudoku Rotate