0

0

Java如何自定义JAXB的类型适配器 XmlAdapter

畫卷琴夢

畫卷琴夢

发布时间:2026-02-03 10:27:10

|

289人浏览过

|

来源于php中文网

原创

XmlAdapter是JAXB提供的双向转换桥梁,用于解决自定义类型或Java 8时间类型等非标准类型与XML映射问题。它将Java对象转为可序列化的中间类型(如String),再转XML;反向同理。

java如何自定义jaxb的类型适配器 xmladapter

什么是XmlAdapter,为什么需要它

JAXB 默认只能处理标准 Java 类型(如 String、Integer、LocalDateTime 等)与 XML 的映射。但实际开发中常遇到自定义类型(比如枚举封装类、带业务逻辑的值对象、第三方库类型),或希望用更简洁/兼容的 XML 格式(如把 LocalDateTime 序列化为 yyyy-MM-dd HH:mm:ss 字符串而非默认的复杂结构)。这时就需要 XmlAdapter —— 它是 JAXB 提供的双向转换桥梁:负责把 Java 对象转成可序列化的“中间类型”,再转成 XML;反向解析时也按此路径逆向还原。

写一个基础 XmlAdapter 示例(String ↔ 自定义 ID 类)

假设你有一个业务 ID 类 OrderId,只含一个 String 字段,但不希望 XML 直接暴露内部结构,而是像普通字符串一样扁平化处理:

// 自定义类型

public class OrderId {
    private final String value;
    public OrderId(String value) { this.value = value; }
    public String getValue() { return value; }
    // 必须有无参构造器(JAXB 反序列化需要)
    private OrderId() { this(""); }
}

// 适配器:String ↔ OrderId

立即学习Java免费学习笔记(深入)”;

public class OrderIdAdapter extends XmlAdapter {
    @Override
    public OrderId unmarshal(String s) throws Exception {
        return s == null || s.trim().isEmpty() ? null : new OrderId(s);
    }

    @Override
    public String marshal(OrderId orderId) throws Exception {
        return orderId == null ? null : orderId.getValue();
    }
}

这个适配器声明了「XML 层用 String,Java 层用 OrderId」,JAXB 在序列化/反序列化时自动调用对应方法。

大同搜索
大同搜索

多语言高质量的AI搜索

下载

在实体类中使用 @XmlJavaTypeAdapter

有两种常用绑定方式:

  • 字段级绑定:最常用,精准控制某字段
public class Order {
    @XmlJavaTypeAdapter(OrderIdAdapter.class)
    private OrderId id;
    private String name;
    // getter/setter...
}
  • 包级绑定(package-info.java:适合全局统一规则,比如所有 LocalDateTime 都用同一种格式

// src/main/java/com/example/model/package-info.java

@XmlJavaTypeAdapters({
    @XmlJavaTypeAdapter(type = LocalDateTime.class, value = LocalDateTimeAdapter.class)
})
package com.example.model;

处理复杂类型:LocalDateTime 适配示例

Java 8 时间类型默认不被 JAXB 支持,需适配。注意:必须指定时区或明确使用「无时区语义」(如仅存日期时间字符串):

public class LocalDateTimeAdapter extends XmlAdapter {
    private static final DateTimeFormatter FORMATTER = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");

    @Override
    public LocalDateTime unmarshal(String s) throws Exception {
        return s == null ? null : LocalDateTime.parse(s, FORMATTER);
    }

    @Override
    public String marshal(LocalDateTime dt) throws Exception {
        return dt == null ? null : dt.format(FORMATTER);
    }
}

使用时同样加注解即可。注意:若 XML 需要带时区(如 Z+08:00),应改用 ZonedDateTimeOffsetDateTime 并调整格式器。

注意事项和常见坑

  • 适配器类必须有无参构造器(JAXB 通过反射实例化)
  • unmarshal 方法中不要抛未检查异常(Exception 是受检异常,必须声明;若想抛 RuntimeException,需包装后转为 Exception 再抛)
  • 如果适配的是集合元素类型(如 List),适配器仍作用于单个元素,无需额外处理集合
  • 避免在 marshal/unmarshal 中做重逻辑(如远程调用、数据库查询),保持轻量和纯函数特性
  • 测试时建议同时验证序列化(marshal)和反序列化(unmarshal)路径

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

543

2023.08.02

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1907

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2095

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1092

2024.11.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

361

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

213

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1505

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

625

2023.11.24

Python 序列化
Python 序列化

本专题整合了python序列化、反序列化相关内容,阅读专题下面的文章了解更多详细内容。

12

2026.02.02

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.2万人学习

C# 教程
C# 教程

共94课时 | 8.4万人学习

Java 教程
Java 教程

共578课时 | 56.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号