贝利信息

Kotlin Serialization怎么序列化为XML

日期:2026-01-14 00:00 / 作者:幻夢星雲
Kotlin Serialization 官方不支持 XML,需用第三方库如 kotlin-xml-serialization(1.4.0)实现;定义 @Serializable 类后,通过 Xml 格式器 encodeToString/decodeFromString 完成序列化与反序列化,支持 @SerialName 映射、缩进及空值处理。

Kotlin Serialization 本身不直接支持 XML 序列化,官方库 kotlinx.serialization 默认只提供 JSON、CBOR 和 Protobuf 的编解码器。要将 Kotlin 数据类序列化为 XML,需借助第三方库或手动桥接。

使用 kotlinx-xml-serialization(推荐)

这是目前最主流的兼容方案,由社区维护,专为 Kotlin Serialization 设计,支持注解驱动的 XML 序列化。

implementation "com.charleskorn.kaml:kaml:0.56.0" // 注意:这不是它 —— 正确是下面这个

✅ 正确依赖(Maven Central 上最新稳定版):

implementation "com.github.microutils:kotlin-xml-serialization:1.4.0"

(注意:该库基于 kotlinx.serialization 扩展,要求 Kotlin ≥ 1.9,Serialization ≥ 1.6)

@Serializable
data class Person(
    val name: String,
    val age: Int,
    @SerialName("is-active") val isActive: Boolean = true
)
val xml = Xml { indent = "  " } // 可选缩进
val person = Person("Alice", 30)
val xmlString = xml.encodeToString(Person.serializer(), person)
// 输出示例:
// 
//   Alice
//   30
//   true
// 

用 Jackson + Kotlin Serialization 桥接(备选)

如果你已有 Jackson XML 支持(jackson-dataformat-xml),可通过适配器把 Kotlin Serialization 的对象转成 Map 或 JsonElement,再交给 Jackson 处理。但这种方式失去原生注解支持,且较繁琐,仅适合已有 Jackson 生态的项目。

注意事项与常见问题

反序列化 XML 同样简单

只要 XML 结构与数据类字段匹配(名称或通过 @SerialName 映射),调用 xml.decodeFromString() 即可:

val xmlStr = "Bob25"
val person: Person = xml.decodeFromString(Person.serializer(), xmlStr)

自动跳过未知字段,支持部分字段缺失(前提是字段可空或有默认值)。