JAXB(Java Architecture for XML Binding) 是一个业界的标准,是一项可以根据XML Schema产生Java类的技术。该过程中,JAXB也提供了将XML实例文档反向生成Java对象树的方法,并能将Java对象树的内容重新写到XML实例文档。从另一方面来讲,JAXB提供了快速而简便的方法将XML模式绑定到Java表示,从而使得Java开发者在Java应用程序中能方便地结合XML数据和处理函数。

JAXBContext 类提供到 JAXB API 的客户端入口点。它提供了管理实现 JAXB 绑定框架操作所需的 XML/Java 绑定信息的抽象,这些操作包括:解组、编组和验证。

  在JDK1.6时,JAXB 2.0是JDK 1.6的组成部分。JAXB 2.2.3是JDK 1.7的组成部分。

 JDK中JAXB相关的重要Class和Interface:

1、JAXBContext类,是应用的入口,用于管理XML/Java绑定信息。

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

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

JDK中JAXB相关的重要Annotation:

1、@XmlType,将Java类或枚举类型映射到XML模式类型

2、@XmlAccessorType(XmlAccessType.FIELD) ,控制字段或属性的序列化。FIELD表示JAXB将自动绑定Java类中的每个非静态的(static)、非瞬态的(由@XmlTransient标注)字段到XML。其他值还有XmlAccessType.PROPERTY和XmlAccessType.NONE。

3、@XmlAccessorOrder,控制JAXB 绑定类中属性和字段的排序。

4、@XmlJavaTypeAdapter,使用定制的适配器(即扩展抽象类XmlAdapter并覆盖marshal()和unmarshal()方法),以序列化Java类为XML。

5、@XmlElementWrapper ,对于数组或集合(即包含多个元素的成员变量),生成一个包装该数组或集合的XML元素(称为包装器)。

6、@XmlRootElement,将Java类或枚举类型映射到XML元素。

7、@XmlElement,将Java类的一个属性映射到与属性同名的一个XML元素。

8、@XmlAttribute,将Java类的一个属性映射到与属性同名的一个XML属性。

DataBean.java

package com.xidian.wq.imaopay.model.mesdata.base;

import javax.xml.bind.annotation.XmlRootElement;

/**
*
* @author BYSocket
* 报文头-[报文基础信息]
*/
@XmlRootElement(name="data_bean")
public class DataBean
{
// 版本信息(data_version)
String version; ////消息类型(data_type)
// 000001 - 注册[个人信息Post|Respose]
// 000002 - 绑定银行卡[首次绑定,保存个人信息]
// 000003 - 绑定银行卡[二次,校验个人信息]
// 100001 - 支付[钱包支付]
// 100002 - 查询
//
String data_type; ////订单编号(order_id)
// 总长20位, 有字母要用大写
String batch_no; // 平台账号(platform_account)
String user_name; ////请求状态
//
String trans_state; // 签名信息(msg_sign)
String msg_sign; // 时间戳(randomTime)
private String rd_time; // 随机数(randomNum)
private String rd_num; // 密钥(keySign)
private String k_sign; // 保留域
String reserve; public String getVersion()
{
return version;
} public void setVersion(String version)
{
this.version = version;
} public String getData_type()
{
return data_type;
} public void setData_type(String data_type)
{
this.data_type = data_type;
} public String getBatch_no()
{
return batch_no;
} public void setBatch_no(String batch_no)
{
this.batch_no = batch_no;
} public String getUser_name()
{
return user_name;
} public void setUser_name(String user_name)
{
this.user_name = user_name;
} public String getTrans_state()
{
return trans_state;
} public void setTrans_state(String trans_state)
{
this.trans_state = trans_state;
} public String getMsg_sign()
{
return msg_sign;
} public void setMsg_sign(String msg_sign)
{
this.msg_sign = msg_sign;
} public String getRd_time()
{
return rd_time;
} public void setRd_time(String rd_time)
{
this.rd_time = rd_time;
} public String getRd_num()
{
return rd_num;
} public void setRd_num(String rd_num)
{
this.rd_num = rd_num;
} public String getK_sign()
{
return k_sign;
} public void setK_sign(String k_sign)
{
this.k_sign = k_sign;
} public String getReserve()
{
return reserve;
} public void setReserve(String reserve)
{
this.reserve = reserve;
} }
RegBean.java
package com.xidian.wq.imaopay.model.mesdata.base; import javax.xml.bind.annotation.XmlRootElement; /**
*
* @author BYSocket
* 报文体-[用户注册报文体信息]
*/
@XmlRootElement(name="reg_bean")
public class RegBean
{ // 注册报文体流水号(reg_data_sn)
private String reg_sn; ////用户编号(user_info_id)
// 业务系统的用户编号只做记录不在支付系统中逻辑处理
private Integer user_id; // 注册账号(reg_account)
private String reg_no; // 注册途径(reg_way)
private String reg_way; // 保留域
private String reserve; ////提交日期(set_time)
// 业务系统上传
private String set_time; // 后台信息返回路径(return_url)
private String ret_url; // 备注
String remarks; public String getReg_sn()
{
return reg_sn;
} public void setReg_sn(String reg_sn)
{
this.reg_sn = reg_sn;
} public Integer getUser_id()
{
return user_id;
} public void setUser_id(Integer user_id)
{
this.user_id = user_id;
} public String getReg_no()
{
return reg_no;
} public void setReg_no(String reg_no)
{
this.reg_no = reg_no;
} public String getReg_way()
{
return reg_way;
} public void setReg_way(String reg_way)
{
this.reg_way = reg_way;
} public String getReserve()
{
return reserve;
} public void setReserve(String reserve)
{
this.reserve = reserve;
} public String getSet_time()
{
return set_time;
} public void setSet_time(String set_time)
{
this.set_time = set_time;
} public String getRet_url()
{
return ret_url;
} public void setRet_url(String ret_url)
{
this.ret_url = ret_url;
} public String getRemarks()
{
return remarks;
} public void setRemarks(String remarks)
{
this.remarks = remarks;
} } 注册报文体MsgRegBean.java,支持内容的列表。 package com.xidian.wq.imaopay.model.mesdata; import java.util.List; import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlElementWrapper;
import javax.xml.bind.annotation.XmlRootElement; import com.xidian.wq.imaopay.model.mesdata.base.DataBean;
import com.xidian.wq.imaopay.model.mesdata.base.RegBean; @XmlRootElement( name = "msg_bean" )
public class MsgRegBean
{
private DataBean dataBean; private List<RegBean> regBeans; public DataBean getDataBean()
{
return dataBean;
} @XmlElement(name = "data_bean")
public void setDataBean(DataBean dataBean)
{
this.dataBean = dataBean;
} @XmlElementWrapper(name = "reg_beans")
@XmlElement(name = "reg_bean")
public List<RegBean> getRegBeans()
{
return regBeans;
} public void setRegBeans(List<RegBean> regBeans)
{
this.regBeans = regBeans;
} }
然后针对的我们用Jaxb实现一个转换的Util类:
package com.xidian.wq.imaopay.util;
import java.io.StringReader;
import java.io.StringWriter;
import java.util.ArrayList;
import java.util.List; import javax.xml.bind.JAXBContext;
import javax.xml.bind.JAXBException;
import javax.xml.bind.Marshaller;
import javax.xml.bind.Unmarshaller; import com.alibaba.fastjson.JSON;
import com.xidian.wq.imaopay.model.mesdata.MsgRegBean;
import com.xidian.wq.imaopay.model.mesdata.base.DataBean;
import com.xidian.wq.imaopay.model.mesdata.base.RegBean; /**
*
* @author BYSocket
* Jaxb2.0 处理Xml与Object转换
*
*/
public class JaxbObjectAndXmlUtil
{ /**
* @param xmlStr 字符串
* @param c 对象Class类型
* @return 对象实例
*/
@SuppressWarnings("unchecked")
public static <T> T xml2Object(String xmlStr,Class<T> c)
{
try
{
JAXBContext context = JAXBContext.newInstance(c);
Unmarshaller unmarshaller = context.createUnmarshaller(); T t = (T) unmarshaller.unmarshal(new StringReader(xmlStr)); return t; } catch (JAXBException e) { e.printStackTrace(); return null; } } /**
* @param object 对象
* @return 返回xmlStr
*/
public static String object2Xml(Object object)
{
try
{
StringWriter writer = new StringWriter();
JAXBContext context = JAXBContext.newInstance(object.getClass());
Marshaller marshal = context.createMarshaller(); marshal.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true); // 格式化输出
marshal.setProperty(Marshaller.JAXB_ENCODING, "UTF-8");// 编码格式,默认为utf-8
marshal.setProperty(Marshaller.JAXB_FRAGMENT, false);// 是否省略xml头信息
marshal.setProperty("jaxb.encoding", "utf-8");
marshal.marshal(object,writer); return new String(writer.getBuffer()); } catch (Exception e) { e.printStackTrace(); return null;} } public static void main(String[] args)
{
/** 构造测试报文头对象 */
DataBean dataBean = new DataBean();
dataBean.setBatch_no("N20150204");
dataBean.setData_type("000001");
dataBean.setVersion("v1.0");
dataBean.setUser_name("xx");
dataBean.setMsg_sign("未知");
dataBean.setRd_num("6631383");
dataBean.setRd_time("20150204");
dataBean.setK_sign("75CC479AAC09F00BA28F0E968B1BC9D1B90ADCC2"); /** 构造测试报文体对象 */
RegBean regBean = new RegBean();
regBean.setReg_sn("REG20150204");
regBean.setUser_id(12);
regBean.setReg_no("33");
regBean.setReg_way("pc");
regBean.setSet_time("20150204 16:18");
regBean.setRet_url("未知");
regBean.setRemarks("无备注"); MsgRegBean msgBean = new MsgRegBean();
List<RegBean> regBeans = new ArrayList<RegBean>();
regBeans.add(regBean);
regBeans.add(regBean); msgBean.setRegBeans(regBeans);
msgBean.setDataBean(dataBean); String xmlStr = JaxbObjectAndXmlUtil.object2Xml(msgBean);//构造报文 XML 格式的字符串
System.out.println("对象转xml报文: \n"+xmlStr); MsgRegBean msgBean2 = JaxbObjectAndXmlUtil.xml2Object(xmlStr, MsgRegBean.class);
System.out.println("报文转xml转: \n"+JSON.toJSONString(msgBean2));
}
} </font> 运行下测试main函数,可以得到如下的输出: 对象转xml报文:
<?xmlversion="1.0"encoding="utf-8"standalone="yes"?>
<msg_bean>
<data_bean>
<batch_no>N20150204</batch_no>
<data_type>000001</data_type>
<k_sign>75CC479AAC09F00BA28F0E968B1BC9D1B90ADCC2</k_sign>
<msg_sign>未知</msg_sign>
<rd_num>6631383</rd_num>
<rd_time>20150204</rd_time>
<user_name>xx</user_name>
<version>v1.0</version>
</data_bean>
<reg_beans>
<reg_bean>
<reg_no>33</reg_no>
<reg_sn>REG20150204</reg_sn>
<reg_way>pc</reg_way>
<remarks>无备注</remarks>
<ret_url>未知</ret_url>
<set_time>20150204 16:18</set_time>
<user_id>12</user_id>
</reg_bean>
<reg_bean>
<reg_no>33</reg_no>
<reg_sn>REG20150204</reg_sn>
<reg_way>pc</reg_way>
<remarks>无备注</remarks>
<ret_url>未知</ret_url>
<set_time>20150204 16:18</set_time>
<user_id>12</user_id>
</reg_bean>
</reg_beans>
</msg_bean> 报文转xml转:
{"dataBean":{"batch_no":"N20150204","data_type":"000001","k_sign":"75CC479AAC09F00BA28F0E968B1BC9D1B90ADCC2","msg_sign":"未知","rd_num":"6631383","rd_time":"20150204","user_name":"xx","version":"v1.0"},"regBeans":[{"reg_no":"33","reg_sn":"REG20150204","reg_way":"pc","remarks":"无备注","ret_url":"未知","set_time":"20150204 16:18","user_id":12},{"reg_no":"33","reg_sn":"REG20150204","reg_way":"pc","remarks":"无备注","ret_url":"未知","set_time":"20150204 16:18","user_id":12}]}
代码中间注意点:
Marshaller.JAXB_FORMATTED_OUTPUT :决定是否在转换成xml时同时进行格式化(即按标签自动换行,否则即是一行的xml) 。 Marshaller.JAXB_ENCODING :xml的编码方式。 Marshaller.JAXB_FRAGMENT :是否省略xml头信息 marshal.setProperty(“jaxb.encoding”, “utf-8″); : 设置编码格式 utf-8

转自:http://my.oschina.net/jeffli1993/blog/376846

java生成解析xml的另外两种方法JAXB的更多相关文章

  1. java生成解析xml的另外两种方法Xstream

    Xstream生成和解析xm和JAXB生成和解析xml的方法. 一,Xstream Xstream非jdk自带的,需要到入Xstream-1.4.3.jar和xpp3_min-1.1.4.jar 1. ...

  2. Java构造和解析Json数据的两种方法详解二

    在www.json.org上公布了很多JAVA下的json构造和解析工具,其中org.json和json-lib比较简单,两者使用上差不多但还是有些区别.下面接着介绍用org.json构造和解析Jso ...

  3. Java构造和解析Json数据的两种方法详解二——org.json

    转自:http://www.cnblogs.com/lanxuezaipiao/archive/2013/05/24/3096437.html 在www.json.org上公布了很多JAVA下的jso ...

  4. Java构造和解析Json数据的两种方法详解一——json-lib

    转自:http://www.cnblogs.com/lanxuezaipiao/archive/2013/05/23/3096001.html 在www.json.org上公布了很多JAVA下的jso ...

  5. .net中创建xml文件的两种方法

    .net中创建xml文件的两种方法 方法1:根据xml结构一步一步构建xml文档,保存文件(动态方式) 方法2:直接加载xml结构,保存文件(固定方式) 方法1:动态创建xml文档 根据传递的值,构建 ...

  6. java 获取键盘输入常用的两种方法

    java 获取键盘输入常用的两种方法 方法1: 通过 Scanner Scanner input = new Scanner(System.in); String s = input.nextLine ...

  7. Android中使用Gson解析JSON数据的两种方法

    Json是一种类似于XML的通用数据交换格式,具有比XML更高的传输效率;本文将介绍两种方法解析JSON数据,需要的朋友可以参考下   Json是一种类似于XML的通用数据交换格式,具有比XML更高的 ...

  8. WCF生成客户端代理对象的两种方法的解释

    最近在封装WCF,有一些很好的实践就记录下来,大家可以放心使用,所有代码都已经调试过.如果有高手可以大家探讨一下. 在WCF中有两种不同的方法可以用于创建客户端服务对象,他们分别为: 1. 代理构造法 ...

  9. Java构造和解析Json数据的两种方法详解一

    一.介绍 JSON-lib包是一个beans,collections,maps,java arrays 和XML和JSON互相转换的包,主要就是用来解析Json数据,在其官网http://www.js ...

随机推荐

  1. css伪类运用

    <!doctype html><html><head><meta charset="utf-8"><title>CSS输 ...

  2. 自然数的K次幂的数列求和

        ------------------------------------------------------------------------------- 转载请注明出处 博客园 刺猬的温 ...

  3. Android--UI

    1.layout_width 属性和 layout_height 属性:Android中所有的控件都包含这两个属性,有三种可选值 match_parent, fill_parent, wrap_con ...

  4. blob及行外数据

    本文中我们假设innodb_page_size为16k,记录格式为compact. 1 大字段 大字段的类型可以参看这里, Data Type Storage Required TINYBLOB, T ...

  5. ASP.NET MVC学习之Ajax(完结)

    一.前言 通过上面的一番学习,大家一定收获不少.但是总归会有一个结束的时候,但是这个结束也意味着新的开始. 如果你是从事ASP.NET开发,并且也使用了第三方控件,那么一定会觉得ASP.NET开发aj ...

  6. C语言宏高级用法 [总结]

    1.前言  今天看代码时候,遇到一些宏,之前没有见过,感觉挺新鲜.如是上网google一下,顺便总结一下,方便以后学习和运用.C语言程序中广泛的使用宏定义,采用关键字define进行定义,宏只是一种简 ...

  7. [WinAPI] API 12 [获取程序所在的目录、程序模块路径,获取和设置当前目录]

    Windows系统提供一组API实现对程序运行时相关目录的获取和设置.用户可以使用GetCurrentDirectory和SetCurrentDirectory获取程序的当前目录,获取模块的路径使用G ...

  8. R 中同步进行的多组比较的包:npmc

    方差检验可以评估组间的差异.依据检验的结果,虽然你可以拒绝不存在差异的原假设,但方差检验并没有告诉你哪些组显著地与其他组有不同.Robert 在 <R in Action>一书中推荐了一个 ...

  9. windows下安装PhpDocumentor(phpdoc)笔记

    PhpDocumentor简介 PHPDocumentor是一个用PHP写的工具,对于有规范注释的php程序,它能够快速生成具有相互参照,索引等功能的API文档.老的版本是phpdoc,从1.3.0开 ...

  10. Atitit. BigConfirmTips 控件 大数据量提示确认控件的原理and总结O9

    Atitit. BigConfirmTips 控件 大数据量提示确认控件的原理and总结O9 1. 主要的涉及的技术 1 2. 主要的流程 1 3. 调用法new confirmO9t(); 1 4. ...