导读:本期聚焦于小伙伴创作的《如何用JAXB实现Java对象与XML的相互转换?完整示例教程》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何用JAXB实现Java对象与XML的相互转换?完整示例教程》有用,将其分享出去将是对创作者最好的鼓励。

Java使用JAXB操作XML示例

JAXB(Java Architecture for XML Binding)是Java平台中用于实现XML与Java对象之间相互转换的技术,通过注解可以将Java类的属性与XML元素、属性进行映射,无需手动编写XML解析和生成的逻辑,大幅简化XML相关操作。下面通过一个完整示例演示如何使用JAXB实现XML的序列化(Java对象转XML)和反序列化(XML转Java对象)。

一、准备实体类

首先需要定义与XML结构对应的Java实体类,通过JAXB相关注解完成映射。下面的示例定义了一个用户类,包含用户基本信息,对应XML中的用户节点结构。

import javax.xml.bind.annotation.*;
import java.util.List;

// 指定该类的根元素名称为user
@XmlRootElement(name = "user")
// 指定XML中元素的排列顺序
@XmlType(propOrder = {"id", "name", "age", "hobbies"})
public class User {
    private Integer id;
    private String name;
    private Integer age;
    private List<String> hobbies;

    // 映射XML中的id属性
    @XmlAttribute(name = "id")
    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    // 映射XML中的name子元素
    @XmlElement(name = "name")
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    // 映射XML中的age子元素
    @XmlElement(name = "age")
    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    // 映射XML中的hobbies集合,每一个hobby对应一个hobby子元素
    @XmlElementWrapper(name = "hobbies")
    @XmlElement(name = "hobby")
    public List<String> getHobbies() {
        return hobbies;
    }

    public void setHobbies(List<String> hobbies) {
        this.hobbies = hobbies;
    }
}

上述代码中用到的JAXB注解说明:

  • @XmlRootElement:指定Java类对应的XML根元素名称,name属性可自定义根元素标签名。
  • @XmlType:propOrder属性用于指定XML中元素的生成顺序,需和类中属性的getter方法顺序对应。
  • @XmlAttribute:将Java属性映射为XML元素的属性,而非子元素。
  • @XmlElement:将Java属性映射为XML元素的子元素,name属性可自定义子元素标签名。
  • @XmlElementWrapper:用于包装集合类型的属性,会在集合外层生成一个父元素。

二、Java对象转XML(序列化)

序列化操作是将构造好的Java对象通过JAXB的上下文和 Marshaller 转换为XML字符串,下面是具体实现代码:

import javax.xml.bind.JAXBContext;
import javax.xml.bind.JAXBException;
import javax.xml.bind.Marshaller;
import java.io.StringWriter;
import java.util.Arrays;

public class JaxbSerializeDemo {
    public static void main(String[] args) {
        try {
            // 1. 构造User对象并设置属性
            User user = new User();
            user.setId(1001);
            user.setName("张三");
            user.setAge(25);
            user.setHobbies(Arrays.asList("篮球", "阅读", "编程"));

            // 2. 创建JAXB上下文,传入需要转换的实体类
            JAXBContext context = JAXBContext.newInstance(User.class);
            // 3. 创建Marshaller对象,用于执行序列化操作
            Marshaller marshaller = context.createMarshaller();
            // 设置格式化输出,生成的XML会自动缩进,方便阅读
            marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
            // 设置编码为UTF-8,避免中文乱码
            marshaller.setProperty(Marshaller.JAXB_ENCODING, "UTF-8");

            // 4. 执行序列化,将对象转换为XML写入字符串输出流
            StringWriter writer = new StringWriter();
            marshaller.marshal(user, writer);

            // 5. 输出生成的XML字符串
            String xmlResult = writer.toString();
            System.out.println("生成的XML内容:");
            System.out.println(xmlResult);
        } catch (JAXBException e) {
            e.printStackTrace();
        }
    }
}

运行上述代码后,会生成如下格式的XML:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<user id="1001">
    <name>张三</name>
    <age>25</age>
    <hobbies>
        <hobby>篮球</hobby>
        <hobby>阅读</hobby>
        <hobby>编程</hobby>
    </hobbies>
</user>

三、XML转Java对象(反序列化)

反序列化操作是将已有的XML字符串通过JAXB的 Unmarshaller 转换为对应的Java对象,下面是具体实现代码:

import javax.xml.bind.JAXBContext;
import javax.xml.bind.JAXBException;
import javax.xml.bind.Unmarshaller;
import java.io.StringReader;

public class JaxbDeserializeDemo {
    public static void main(String[] args) {
        // 待转换的XML字符串
        String xmlContent = "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\n" +
                "<user id=\"1001\">\n" +
                "    <name>张三</name>\n" +
                "    <age>25</age>\n" +
                "    <hobbies>\n" +
                "        <hobby>篮球</hobby>\n" +
                "        <hobby>阅读</hobby>\n" +
                "        <hobby>编程</hobby>\n" +
                "    </hobbies>\n" +
                "</user>";

        try {
            // 1. 创建JAXB上下文,传入目标实体类
            JAXBContext context = JAXBContext.newInstance(User.class);
            // 2. 创建Unmarshaller对象,用于执行反序列化操作
            Unmarshaller unmarshaller = context.createUnmarshaller();

            // 3. 执行反序列化,将XML字符串转换为User对象
            StringReader reader = new StringReader(xmlContent);
            User user = (User) unmarshaller.unmarshal(reader);

            // 4. 输出反序列化后的对象属性
            System.out.println("反序列化得到的User信息:");
            System.out.println("用户ID:" + user.getId());
            System.out.println("用户姓名:" + user.getName());
            System.out.println("用户年龄:" + user.getAge());
            System.out.println("用户爱好:" + user.getHobbies());
        } catch (JAXBException e) {
            e.printStackTrace();
        }
    }
}

运行上述代码后,控制台会输出反序列化得到的User对象的各个属性值,说明XML成功转换为了对应的Java对象。

四、注意事项

1. JAXB在Java 8及之前版本是内置的,从Java 9开始,JAXB被标记为废弃,Java 11及之后版本不再默认包含,如果需要使用,需要手动引入相关依赖,例如Maven项目可添加以下依赖:

<dependency>
    <groupId>javax.xml.bind</groupId>
    <artifactId>jaxb-api</artifactId>
    <version>2.3.1</version>
</dependency>
<dependency>
    <groupId>com.sun.xml.bind</groupId>
    <artifactId>jaxb-impl</artifactId>
    <version>2.3.1</version>
</dependency>
<dependency>
    <groupId>com.sun.xml.bind</groupId>
    <artifactId>jaxb-core</artifactId>
    <version>2.3.1</version>
</dependency>

2. 实体类必须要有无参构造方法,JAXB在反序列化时会通过无参构造创建对象,再赋值属性,如果没有无参构造会抛出相关异常。

3. 注解的使用要符合规范,如果属性是私有的,建议将注解加在getter方法上,避免和字段注解冲突。

JAXBJava对象转XMLXML反序列化注解配置Java XML操作 本作品最后修改时间:2026-05-22 21:42:05

免责声明:网站部分内容来源于网络或由用户自行发表,内容观点不代表本站立场。本站是个人网站免费分享,内容仅供个人学习、研究或参考使用,如内容中引用了第三方作品,其版权归原作者所有。若内容触犯了您的权益,请联系我们进行处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。前端、网络、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握网站开发与运维所需的核心技术栈。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端逻辑,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。