Java 序列化之JAXB完全解读

2023-11-11 23:32

本文主要是介绍Java 序列化之JAXB完全解读,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

欢迎大家关注本博,同时欢迎大家评论交流,可以给个赞哦!!!

  JAXB 简介

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

  JAXB 2.0是JDK 1.6的组成部分。JAXB 2.2.3是JDK 1.7的组成部分。

  JAXB API

  · JAXBContext:应用入口,负责创建编组和解组实例。

  · Marshaller:编组接口,用于将Java对象序列化为XML数据。

  · Unmarshaller:解组接口,用于将XML数据反序列化为Java对象。

  JAXB 工具类

  依照本博客习惯,提供JAXB工具类,可以直接使用,完成Java Bean与XML的序列化和反序列化。

package com.arhorchin.securitit.serialize.jaxb;import java.io.StringReader;
import java.io.StringWriter;import javax.xml.bind.JAXBContext;
import javax.xml.bind.Marshaller;
import javax.xml.bind.Unmarshaller;/*** @author Securitit.* @note JAXB XML转换标准实现.*/
public class JaxbXmlUtil {/*** JavaBean转换成xml.* @param obj JavaBean.* @param encoding 字符集.* @return XML数据.*/public static String javaBeanToXml(Object obj, String encoding) {String result = null;JAXBContext context = null;Marshaller marshaller = null;StringWriter writer = null;try {context = JAXBContext.newInstance(obj.getClass());marshaller = context.createMarshaller();marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);marshaller.setProperty(Marshaller.JAXB_ENCODING, encoding);writer = new StringWriter();marshaller.marshal(obj, writer);result = writer.toString();} catch (Exception e) {return null;}return result;}/*** Xml转换成JavaBean.* @param xml XML.* @param clazz JavaBean类对象.* @return JavaBean.*/public static <T> T xmlToJavaBean(String xml, Class<T> clazz) {T t = null;JAXBContext context = null;Unmarshaller unmarshaller = null;try {context = JAXBContext.newInstance(clazz);unmarshaller = context.createUnmarshaller();t = (T) unmarshaller.unmarshal(new StringReader(xml));} catch (Exception e) {return null;}return t;}}

  JAXB 工具类实例

  首先新建一个JavaBean,用于进行序列化和反序列化的转换,如下:

package com.arhorchin.securitit.serialize.jaxb;import java.io.Serializable;import javax.xml.bind.annotation.XmlRootElement;/*** @author Securitit.* @note JAXB演示Bean.*/
@XmlRootElement(name = "people")
public class JaxbBean {/*** name.*/private String name;/*** address.*/private String address;public String getName() {return name;}public void setName(String name) {this.name = name;}public String getAddress() {return address;}public void setAddress(String address) {this.address = address;}@Overridepublic String toString() {return "{\"name\": \"" + name + "\", \"address\": \"" + address + "\"}";}}

  接着,我们使用测试JaxbUtil进行序列化和反序列化测试,如下:

package com.arhorchin.securitit.serialize.jaxb;/*** @author Securitit.* @note JaxbUtil测试类.*/
public class JaxbUtilTester {public static void main(String[] args) {JaxbBean bean = null;String xmlStr = null;JaxbBean vBean = null;bean = new JaxbBean();bean.setName("Securitit");bean.setAddress("China");// 序列化.xmlStr = JaxbUtil.javaBeanToXml(bean, "UTF-8");System.out.println("---------------- 序列化结果  ----------------");System.out.println(xmlStr);vBean = JaxbUtil.xmlToJavaBean(xmlStr, JaxbBean.class);System.out.println("---------------- 反序列化结果  ----------------");System.out.println(vBean);}}

  运行输出结果如下:

---------------- 序列化结果  ----------------
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<people><address>China</address><name>Securitit</name>
</people>---------------- 反序列化结果  ----------------
{"name": "Securitit", "address": "China"}

  总结

  · JaxbXmlUtil工具类,复制即可使用,除包路径外无需做任何更改。

  · JAXB涉及众多注解,除了本文使用的@XmlRootElement,还有很多其他注解,将会在接下来的系列博文中进行详细讲解。

本博微信公众号“超哥说码”,欢迎大家订阅,公众号正在完善中,会及时将更优质的博文推送于您!
在这里插入图片描述

这篇关于Java 序列化之JAXB完全解读的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/393574

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

每天认识几个maven依赖(ActiveMQ+activemq-jaxb+activesoap+activespace+adarwin)

八、ActiveMQ 1、是什么? ActiveMQ 是一个开源的消息中间件(Message Broker),由 Apache 软件基金会开发和维护。它实现了 Java 消息服务(Java Message Service, JMS)规范,并支持多种消息传递协议,包括 AMQP、MQTT 和 OpenWire 等。 2、有什么用? 可靠性:ActiveMQ 提供了消息持久性和事务支持,确保消

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听