JAVA Bean和XML之间的相互转换 - XStream简单入门
JAVA Bean和XML之间的相互转换 - XStream简单入门
背景介绍
我们在工作中经常 遇到文件解析为数据或者数据转化为xml文件的情况,之前我一直采用的方式都是手动的来解析或拼接XML文件,这个做法固然是可以的,但是代码部分会显得非常臃肿,所以就查找了相关的资料,发现了一个名为XStream的类库可以做这件事,下面我们来看一下.
XStream的简介
从官网介绍我们能看到以下几个特性:
- 易用
- 不需要Mapping文件
不需要额外提供Mapping文件即可完成映射
- 高性能
高速且低内存消耗
- 整洁的XML文件
生成的XML的相当简洁
- 不需要修改对象
可以序列化private修饰的属性,且不需要提供get/set方法
- 完整的对象结构支持
支持循环引用情况下的输出
- 兼容其他的XML API
可以对任何的树形结构进行序列化或反序列化
- 可以自定义的转换策略
可以通过策略的注册,允许自定义特定类型的转化为XML的样式
- 安全的框架
对未分组的类型进行精细化的控制,防止输入错误而导致的安全问题
- 良好的异常反馈
当XML文件格式错误的时候,能够提供诊断信息帮助处理
- 多样的输出格式
不止是XML他还支持JSON及其变种
注解简介
从XStream的官网我们了解到,XStream不需要Mapping文件就能完成JavaBean和XML之间的转变,但大部分时候我们需要对生成的XML文件进行定制,name我们需要了解XStream提供的注解
注解 | 作用 | 适用范围 |
---|---|---|
@XStreamAlias | 设置别名 | 类或属性 |
@XStreamImplicit | 忽略属性 | 集合类型的属性 |
@XStreamAsAttribute | 将JavaBean转换成节点属性 | 属性 |
@XStreamOmitField | 忽略属性 | 属性 |
@XStreamConverter | 注入转换器 | 类 |
应用实例
首先在我们的项目中加入依赖:
<dependency>
<groupId>com.thoughtworks.xstream</groupId>
<artifactId>xstream</artifactId>
<version>1.4.11.1</version>
</dependency>
假定环境为Computer和CPU两个类:
public class Computer implements Serializable {
private static final long serialVersionUID = 567119860357020081L;
private String name;
private String brand;
private List<CPU> processors;
public Computer() {
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getBrand() {
return brand;
}
public void setBrand(String brand) {
this.brand = brand;
}
public List<CPU> getProcessors() {
return processors;
}
public void setProcessors(List<CPU> processors) {
this.processors = processors;
}
}
public class CPU implements Serializable {
private static final long serialVersionUID = -718438777162957779L;
private String name;
private String generation;
public CPU() {
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getGeneration() {
return generation;
}
public void setGeneration(String generation) {
this.generation = generation;
}
}
写一个测试方法:
import com.hykj.facheck.entity.CPU;
import com.hykj.facheck.entity.Computer;
import com.thoughtworks.xstream.XStream;
import com.thoughtworks.xstream.io.xml.DomDriver;
import java.util.ArrayList;
import java.util.List;
public class XStreamTest {
public static void main(String[] args) {
List<CPU> cpuList = new ArrayList<>();
CPU cpu1 = new CPU();
cpu1.setGeneration("8-i5-K");
cpu1.setName("第一个");
cpuList.add(cpu1);
CPU cpu2 = new CPU();
cpu2.setGeneration("8-i5-U");
cpu2.setName("第二个");
cpuList.add(cpu2);
Computer computer = new Computer();
computer.setBrand("huawei");
computer.setName("wej-laptop");
computer.setProcessors(cpuList);
XStream xstream = new XStream(new DomDriver());
xstream.ignoreUnknownElements();
xstream.processAnnotations(Computer.class);
//javabean to xml
String xml = xstream.toXML(computer);
System.out.println(xml);
//xml to javabean
Computer computerFromXml = (Computer) xstream.fromXML(xml);
System.out.println(computer.getName());
}
}
运行程序,控制台打结果如下:
Connected to the target VM, address: '127.0.0.1:53977', transport: 'socket'
<com.hykj.facheck.entity.Computer>
<name>wej-laptop</name>
<brand>huawei</brand>
<processors>
<com.hykj.facheck.entity.CPU>
<name>第一个</name>
<generation>8-i5-K</generation>
</com.hykj.facheck.entity.CPU>
<com.hykj.facheck.entity.CPU>
<name>第二个</name>
<generation>8-i5-U</generation>
</com.hykj.facheck.entity.CPU>
</processors>
</com.hykj.facheck.entity.Computer>
Security framework of XStream not initialized, XStream is probably vulnerable.
wej-laptop
Disconnected from the target VM, address: '127.0.0.1:53977', transport: 'socket'
Process finished with exit code 0
也就是说这样就可以用了,很棒棒
但是这个XML和我们的需求不太一样,我们加上注解,代码变成了这样:
import com.thoughtworks.xstream.annotations.XStreamAlias;
import java.io.Serializable;
import java.util.List;
@XStreamAlias("my")
public class Computer implements Serializable {
private static final long serialVersionUID = 567119860357020081L;
private String name;
private String brand;
@XStreamAlias("cpuList")
private List<CPU> processors;
public Computer() {
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getBrand() {
return brand;
}
public void setBrand(String brand) {
this.brand = brand;
}
public List<CPU> getProcessors() {
return processors;
}
public void setProcessors(List<CPU> processors) {
this.processors = processors;
}
}
import com.thoughtworks.xstream.annotations.XStreamAlias;
import java.io.Serializable;
@XStreamAlias("oneCpu")
public class CPU implements Serializable {
private static final long serialVersionUID = -718438777162957779L;
private String name;
private String generation;
public CPU() {
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getGeneration() {
return generation;
}
public void setGeneration(String generation) {
this.generation = generation;
}
}
测试方法不变,结果如下:
Connected to the target VM, address: '127.0.0.1:54181', transport: 'socket'
<my>
<name>wej-laptop</name>
<brand>huawei</brand>
<cpuList>
<oneCpu>
<name>第一个</name>
<generation>8-i5-K</generation>
</oneCpu>
<oneCpu>
<name>第二个</name>
<generation>8-i5-U</generation>
</oneCpu>
</cpuList>
</my>
Security framework of XStream not initialized, XStream is probably vulnerable.
wej-laptop
Disconnected from the target VM, address: '127.0.0.1:54181', transport: 'socket'
Process finished with exit code 0
这个XML就很舒服啦.
我们载试一下循环引用的情况吧,代码如下:
import com.thoughtworks.xstream.annotations.XStreamAlias;
import java.io.Serializable;
import java.util.List;
@XStreamAlias("my")
public class Computer implements Serializable {
private static final long serialVersionUID = 567119860357020081L;
private String name;
private String brand;
@XStreamAlias("cpuList")
private List<CPU> processors;
public Computer() {
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getBrand() {
return brand;
}
public void setBrand(String brand) {
this.brand = brand;
}
public List<CPU> getProcessors() {
return processors;
}
public void setProcessors(List<CPU> processors) {
this.processors = processors;
}
}
import com.thoughtworks.xstream.annotations.XStreamAlias;
import java.io.Serializable;
@XStreamAlias("oneCpu")
public class CPU implements Serializable {
private static final long serialVersionUID = -718438777162957779L;
private String name;
private String generation;
private Computer computer;
public CPU() {
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getGeneration() {
return generation;
}
public void setGeneration(String generation) {
this.generation = generation;
}
public Computer getComputer() {
return computer;
}
public void setComputer(Computer computer) {
this.computer = computer;
}
}
import com.thoughtworks.xstream.XStream;
import com.thoughtworks.xstream.io.xml.DomDriver;
import java.util.ArrayList;
import java.util.List;
public class XStreamTest {
public static void main(String[] args) {
Computer computer = new Computer();
computer.setBrand("huawei");
computer.setName("wej-laptop");
List<CPU> cpuList = new ArrayList<>();
CPU cpu1 = new CPU();
cpu1.setGeneration("8-i5-K");
cpu1.setName("第一个");
cpu1.setComputer(computer);
cpuList.add(cpu1);
CPU cpu2 = new CPU();
cpu2.setGeneration("8-i5-U");
cpu2.setName("第二个");
cpuList.add(cpu2);
cpu1.setComputer(computer);
computer.setProcessors(cpuList);
XStream xstream = new XStream(new DomDriver());
xstream.ignoreUnknownElements();
xstream.processAnnotations(Computer.class);
//javabean to xml
String xml = xstream.toXML(computer);
System.out.println(xml);
//xml to javabean
Computer computerFromXml = (Computer) xstream.fromXML(xml);
System.out.println(computer.getName());
}
}
运行一下,先查看是否构成循环引用:
确认有循环引用,继续运行代码,控制台打印如下:
Connected to the target VM, address: '127.0.0.1:54221', transport: 'socket'
<my>
<name>wej-laptop</name>
<brand>huawei</brand>
<cpuList>
<oneCpu>
<name>第一个</name>
<generation>8-i5-K</generation>
<computer reference="../../.."/>
</oneCpu>
<oneCpu>
<name>第二个</name>
<generation>8-i5-U</generation>
</oneCpu>
</cpuList>
</my>
Security framework of XStream not initialized, XStream is probably vulnerable.
wej-laptop
Disconnected from the target VM, address: '127.0.0.1:54221', transport: 'socket'
Process finished with exit code 0
可以看到生成的XML中采用类似路径的reference属性来标识了位置,实际上我们一般是需要忽略这个属性的,采用@XStreamOmitField注解就好了.
JAVA Bean和XML之间的相互转换 - XStream简单入门的更多相关文章
- JAVA bean与XML互转的利器---XStream
最近在项目中遇到了JAVA bean 和XML互转的需求, 本来准备循规蹈矩使用dom4j忽然想起来之前曾接触过的XStream, 一番研究豁然开朗,利器啊利器, 下来就XStream的一些用法与大家 ...
- JAXB实现java对象与xml之间转换
JAXB简介: 1.JAXB能够使用Jackson对JAXB注解的支持实现(jackson-module-jaxb-annotations),既方便生成XML,也方便生成JSON,这样一来可以更好的标 ...
- 简单Java类与XML之间的转换
需要的jar包:xmlpull_1_0_5.jar,xstream-1.4.1.jar) 1.工具类XstreamUtil package com.learn.util; import com.tho ...
- JSON-lib框架,JAVA对象与JSON、XML之间的相互转换
Json-lib可以将Java对象转成json格式的字符串,也可以将Java对象转换成xml格式的文档,同样可以将json字符串转换成Java对象或是将xml字符串转换成Java对象. 一. 准备工作 ...
- 通过JAXB完成Java对象与XML之间的转换
Java对象转换XML的过程叫marshal. XML转换到Java对象的过程叫unmarshal. 一.Java对象转化为XML 这里省略getter和setter方法 通过标注@XMLRootEl ...
- JAXB 实现java对象与xml之间互相转换
首先熟悉一下JAXB实现对象与xml互转时常用的一些注解使用: 1.@XmlRootElement,用于类级别的注解,对应xml的跟元素.通过name属性定义这个根节点的名称. 2.@XmlAcces ...
- jaxb 专题一(JAXB 实现java对象与xml之间互相转换)
首先熟悉一下JAXB实现对象与xml互转时常用的一些注解使用: 1.@XmlRootElement,用于类级别的注解,对应xml的跟元素.通过name属性定义这个根节点的名称. 2.@XmlAcces ...
- Java 里面各种类型之间的相互转换
1.整形与字符型之间的数据类型转换: 一.int转换成char有两种方法: ① 是利用char的unicode编码 例:int num1 = 8; char ch1 = (char) (num1 + ...
- Java Bean与Map之间相互转化的实现
目录树 概述 Apache BeanUtils将Bean转Map Apache BeanUtils将Map转Bean 理解BeanUtils将Bean转Map的实现之手写Bean转Map 概述 Apa ...
随机推荐
- 前端页面JS和CSS以及图片加载nginx报错:net::ERR_CONTENT_LENGTH_MISMATCH的解决与检查
首先检查nginx权限 具体可参考地址https://www.cnblogs.com/hooly/p/9951748.html 或者百度其他方法 还有种情况,之前是可以用的,突然出现这种加载报错的情况 ...
- 第8章 IO库 自我综合练习
要求: 文本内容: Tom 11144455 12345678998 Jone 88888888 99999999999 1.将文本文件中的内容读入,并显示到屏幕上: 2.手动输入“Mary 77 ...
- TCP/IP的4层模型
1.网络接入层:将需要相互连接的节点接入网络中,从而为数据传输提供条件: 2.网际互联层:找到要传输数据的目标节点: 3.传输层:实际传输数据: 4.应用层:使用接收到的数据: 形象一点的介绍:整个分 ...
- R语言-时间序列图
1.时间序列图 plot()函数 > air<-read.csv("openair.csv") > plot(air$nox~as.Date(air$date,& ...
- fair scheduler配置
<property> <name>yarn.resourcemanager.scheduler.class</name> <value>or ...
- day46 前端基础HTML5+CSS3
编辑器 pycharm,sublime,hbuild,webstorm,atom 前端概念 广义:用户能看见并且交互的显示页面 狭义:运行在浏览器上的页面 学习的语言 html5 => (h5架 ...
- Pandas透视表和交叉表
透视表 参数名 说明 values 待聚合的列的名称.默认聚合所有数值列 index 用于分组的列名或其他分组键,出现在结果透视表的行 columns 用于分组的列表或其他分组键,出现在结果透视表的列 ...
- ucos中需要注意的全局变量
首先聊一聊全局变量: 在慕课上学习浙大老师的C语言课程的时候,翁恺老师一直在强调在程序中我们要避免使用全局变量,C语言的程序员(尤其像我这样的野生程序员)为了方便,经常会不顾这个编码规范.全局变量有一 ...
- DVWA中low级的sql注入漏洞的简单复现
第一次成功复现一个简单漏洞,于是写下这篇随笔记录一下 首先我们来看dvwa中low级的sql注入的源码 源码文件路径如下图: 源码如下: <?php if(isset($_GET['Submit ...
- redis设置密码
1.初始化Redis密码: 在redis.conf配置文件中有个参数: requirepass 这个就是配置redis访问密码的参数: 比如 requirepass test123: (Ps:需重启 ...