JAVA对象和XML文档、原来他们之间还有这一出
最近项目开发中遇到一个问题,访问接口不再通过url地址请求的方式,而是
通过socket发送xml格式的报文到指定服务器来进行信息的统一认证。。
因此组装xml格式的报文字符串以及解析服务器返回的xml格式的字符获得所需数据成了
解决问题的关键。。在这之前,以为会有点难。。。做完之后,然并卵,也就那么一回事。。。
LZ主要用的xStream类。。这个类的完美地解决了XML文档和JAVA对象之间的转换。。
由于刚刚接触这个类。。。对于里面提供的很多功能还没细细挖掘。。只是简单地实现了
我想要实现的功能。。待后续有时间再细嚼慢咽、细细品味。。。
Entrance类:主要提供程序运行的入口。。。
该类中包含了一个静态的generateHtml()方法、用于生成XML格式的字符串
package com.linjm.xml;
public class Entrance {
public static void main(String[] args) {
String html = generateHtml();
System.out.println("############################");
TagEntity tagEntity = XMLUtil.fromXml(html, TagEntity.class);
System.out.println("解析HTML:");
System.out.println("title:" + tagEntity.getHead().getTitle());
System.out.println("输出类信息:");
System.out.println(tagEntity.toString());
}
public static String generateHtml() {
TagEntity tagEntity = new TagEntity();
Head head = Init.initHead();
Body body = Init.initBody();
tagEntity.setHead(head);
tagEntity.setBody(body);
String html = XMLUtil.toXml(tagEntity);
String top = "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">\n";
System.out.println("生成HTML:\n" + top + html);
return html;
}
}
先看下程序的运行结果吧。。。看完我们再看后面具体的代码结构。。。
生成HTML:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Title</title>
<meta>Meta</meta>
<js>JavaScript</js>
<css>CSS</css>
</head>
<body>
<div>Div</div>
<span>Span</span>
<font>Front</font>
<input>Input</input>
</body>
</html>
############################
解析HTML:
title:Title
输出类信息:
head:[title:Title,meta:Meta,js:JavaScript,css:CSS],body:[div:Div,input:Input,font:Front,span:Span]
Init类:主要用于初始化XML中的Head和Body标签内的子标签内容。。。
package com.linjm.xml;
public class Init {
public static Head initHead() {
Head head = new Head();
head.setTitle("Title");
head.setMeta("Meta");
head.setJs("JavaScript");
head.setCss("CSS");
return head;
}
public static Body initBody() {
Body body = new Body();
body.setDiv("Div");
body.setFont("Front");
body.setInput("Input");
body.setSpan("Span");
return body;
}
}
TagEntity类:主要是包含了两个字段:head和body。
也是最终xml中呈现的head标签和body标签。。。
通过@XStreamAlias注解的方式定义标签中的xml显示内容。。。
大家可以根据自己的需求定义不同的标签。。。
head和body标签可根据需求不同而不同。。。
package com.linjm.xml;
import com.thoughtworks.xstream.annotations.XStreamAlias;
@XStreamAlias("html")
public class TagEntity {
@XStreamAlias("head")
private Head head;
@XStreamAlias("body")
private Body body;
public Head getHead() {
return head;
}
public void setHead(Head head) {
this.head = head;
}
public Body getBody() {
return body;
}
public void setBody(Body body) {
this.body = body;
}
public String toString() {
String str = "head:[" +
"title:"+ head.getTitle() +
",meta:"+ head.getMeta() +
",js:"+ head.getJs() +
",css:"+ head.getCss() +
"]," +
"body:[" +
"div:"+ body.getDiv() +
",input:"+ body.getInput() +
",font:"+ body.getFont() +
",span:"+ body.getSpan() +
"]";
return str;
}
}
Head类:该实体类中定义了head标签中的子标签属性字段。。 。
head标签中的子标签可依据具体实际情况而定
package com.linjm.xml;
import com.thoughtworks.xstream.annotations.XStreamAlias;
public class Head {
@XStreamAlias("title")
private String title;
@XStreamAlias("meta")
private String meta;
@XStreamAlias("js")
private String js;
@XStreamAlias("css")
private String css;
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getMeta() {
return meta;
}
public void setMeta(String meta) {
this.meta = meta;
}
public String getJs() {
return js;
}
public void setJs(String js) {
this.js = js;
}
public String getCss() {
return css;
}
public void setCss(String css) {
this.css = css;
}
}
Body类:该实体类中 定义了body标签中的子标签属性字段。。。
body标签中的子标签可依据具体实际情况而定。。。
package com.linjm.xml;
import com.thoughtworks.xstream.annotations.XStreamAlias;
public class Body {
@XStreamAlias("div")
private String div;
@XStreamAlias("span")
private String span;
@XStreamAlias("font")
private String font;
@XStreamAlias("input")
private String input;
public String getDiv() {
return div;
}
public void setDiv(String div) {
this.div = div;
}
public String getSpan() {
return span;
}
public void setSpan(String span) {
this.span = span;
}
public String getFont() {
return font;
}
public void setFont(String font) {
this.font = font;
}
public String getInput() {
return input;
}
public void setInput(String input) {
this.input = input;
}
}
XMLUtil类:该类定义了xStream中组装XML字符串和解析XML字符串封装方法。。。
toXml()方法用于将Java对象转为XML字符串;
fromXml()方法用于解析XML字符串转换为Java对象。
package com.linjm.xml; import com.thoughtworks.xstream.XStream;
import com.thoughtworks.xstream.io.xml.DomDriver; public class XMLUtil { /**
* @desc 将JAVA对象转XML字符串
* @author JimLy
* @date 20160423
* */
public static String toXml(Object obj) {
XStream xs = new XStream(new DomDriver());
xs.processAnnotations(obj.getClass()); return xs.toXML(obj);
} /**
* @desc 将XML字符串转JAVA对象
* @author JimLy
* @date 20160423
* */
@SuppressWarnings("unchecked")
public static <T> T fromXml(String xmlStr, Class<T> cls) {
XStream xs = new XStream(new DomDriver());
xs.processAnnotations(cls);
T obj = (T) xs.fromXML(xmlStr); return obj;
} }
代码实现很简单,也并不是很复杂。。。基本上都是可以看得懂的。。。
为了不使代码篇幅太长,我还是分多个类文件写、就不都写在一个类文件中。。
程序结构设计上存在点瑕疵,,有点啰嗦。。目前只体现出程序的功能。。。
对于xStream也是初次涉及,,也许、大概可能吧、会存在更好的实现方法以及
程序设计上需要优化的地方另当别论。。。
看完博文觉得对这个有点兴趣的话,可以自己动手code一番。。。
也不枉花了这么多时间来看,,既然看了就得有点收获不是吗。。。
需要用到的jar包:xstream-1.4.7.jar
JAVA对象和XML文档、原来他们之间还有这一出的更多相关文章
- 精讲 org.w3c.dom(java dom)解析XML文档
org.w3c.dom(java dom)解析XML文档 位于org.w3c.dom操作XML会比较简单,就是将XML看做是一颗树,DOM就是对这颗树的一个数据结构的描述,但对大型XML文件效果可能会 ...
- org.w3c.dom(java dom)解析XML文档
位于org.w3c.dom操作XML会比较简单,就是将XML看做是一颗树,DOM就是对这颗树的一个数据结构的描述,但对大型XML文件效果可能会不理想 首先来了解点Java DOM 的 API:1.解析 ...
- 详解xml文件描述,读取方法以及将对象存放到xml文档中,并按照指定的特征寻找的方案
主要的几个功能: 1.完成多条Emp信息的XML描述2.读取XML文档解析Emp信息3.将Emp(存放在List中)对象转换为XML文档4.在XML文档中查找指定特征的Emp信息 dom4j,jaxe ...
- 浅谈用java解析xml文档(四)
继续接上一文,这一阵子因为公司项目加紧,导致最后一个解析xml文档的方式,还没有总结,下面总结使用dom4J解析xml. DOM4J(Document Object Model for Java) 使 ...
- 浅谈用java解析xml文档(三)
接上一篇,本文介绍使用JDOM解析xml文档, 首先我们还是应该知道JDOM从何而来,是Breet Mclaughlin和Jason Hunter两大Java高手的创作成果,2000年初, JDOM作 ...
- Java高级特性 第13节 解析XML文档(1) - DOM和XPath技术
一.使用DOM解析XML文档 DOM的全称是Document Object Model,也即文档对象模型.在应用程序中,基于DOM的XML分析器将一个XML文档转换成一个对象模型的集合(通常称DOM树 ...
- dom4j解析xml文档全面介绍
一.dom4j介绍 dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的.dom4j是一个非常非常优秀的Java XML API,具有性能优异.功能强大和极端易用使用的特点, ...
- 文档对象模型操作xml文档
简介 :文档对象模型(DOM)是一种用于处理xml文档的API函数集. 2.1文档对象模型概述 按照W3C的定义,DOM是“一种允许程序或脚本动态地访问更新文档内容,结构和样式的.独立于平台和语言的规 ...
- 使用GDataXML生成、修改XML文档-陈棚
使用GDXML生成XML文档的步骤如下. 1.调用GDataXMLNode的elementWithName:方法创建GDataXMLElement对象,对象作为XML文档的根元素. 2.调用GData ...
随机推荐
- SQL Server(四)——查询练习(45道习题)
题目:设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher). 四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1 ...
- SQL Server 分页方法汇总
PageSize = 30 PageNumber = 201 方法一:(最常用的分页代码, top / not in) UserId UserId from UserInfo order by Use ...
- App_Data 目录中的数据库位置指定了一个本地 SQL Server
<configuration> <system.web> <compilation debug="true" targetFramework=&quo ...
- android Bitmap类方法属性 详细说明
(转:http://blog.csdn.net/ymangu666/article/details/37729109) 1. BitMap类public void recycle()——回收位图占用 ...
- Altium Designer 出现错误提示(警告)adding items to hidden net GND/VCC
一般出现这个提示,不是错误. 可以取消net 网格标号 这样就不会报这个警告了. 还可以设置规则,不让它报告. 点击确定,但是再次打开工程时有得警告这个错误了.我想,还是取消NET标注.
- 深入理解TCP(一)
TCP是面向连接的传输层层协议,可以为应用层提供可靠的数据传输服务.所谓的面向连接并不是真正意思上的连接,只不过是在发送数据之前,首先得相互握手,也就是说接收方知道你要发数据给它了.而UDP是面向无连 ...
- KVM 介绍(7):使用 libvirt 做 QEMU/KVM 快照和 Nova 实例的快照 (Nova Instances Snapshot Libvirt)
学习 KVM 的系列文章: (1)介绍和安装 (2)CPU 和 内存虚拟化 (3)I/O QEMU 全虚拟化和准虚拟化(Para-virtulizaiton) (4)I/O PCI/PCIe设备直接分 ...
- Struts2中的Unable to load configuration错误的分析与解决方法
当我们遇到 Unable to load configuration. 这样的错误时,可以根据具体的错误提示找出错误的原因. Unable to load configuration. - inter ...
- POJ 3384 Feng Shui --直线切平面
题意:房间是一个凸多边形,要在里面铺设两条半径为r的圆形地毯,可以重叠,现在要求分别铺设到哪,使地毯所占的地面面积最大. 解法:要使圆形地毯所占面积最大,圆形地毯一定是与边相切的,这样才能使尽量不重叠 ...
- USACO GCD Extreme(II)
题目大意:求gcd(1,2)+gcd(1,3)+gcd(2,3)+...+gcd(n-1,n) ---------------------------------------------------- ...