0

0

Apache Camel中的XML数据格式转换

畫卷琴夢

畫卷琴夢

发布时间:2026-03-10 09:30:02

|

654人浏览过

|

来源于php中文网

原创

camel中xml与java对象转换首选camel-jaxb组件,需复用jaxbcontext、正确配置命名空间与空元素处理;定制输出格式须通过jaxbdataformat.configuration;复杂xml推荐camel-jacksonxml替代。

apache camel中的xml数据格式转换

Camel中用camel-jaxb处理XML转Java对象

XML到Java对象的转换在Camel里最常用的是camel-jaxb组件,它底层依赖JAXB 2.x,适合结构稳定、有XSD或已知POJO类的场景。不推荐直接用camel-xstream(已弃用)或手动解析DocumentBuilder——既绕过Camel的类型路由能力,又难统一异常处理。

关键点是:JAXBContext必须复用,不能每次路由都新建;否则会严重拖慢吞吐量,尤其高并发时CPU和GC压力明显上升。

  • 确保你的POJO类标注了@XmlRootElement或通过JaxbDataFormat显式指定contextPath
  • 若XML含命名空间,POJO需用@XmlSchema声明namespace,且JaxbDataFormat要设ignoreNamespace = false
  • 空元素(如<price></price>)默认映射为null,若需转成0或空字符串,得在POJO字段加@XmlElement(nillable = true)并配合自定义XmlAdapter
from("file:input?noop=true")
  .unmarshal(new JaxbDataFormat("com.example.invoice"))
  .process(exchange -> {
      Invoice invoice = exchange.getIn().getBody(Invoice.class);
      // 处理逻辑
  });

Java对象转XML时控制格式与编码

默认生成的XML无缩进、无声明头、编码固定为UTF-8。生产环境常需定制:比如对接老系统要求encoding="GBK",或日志调试需要可读缩进。

JaxbDataFormat本身不暴露Marshaller配置入口,得用setConfiguration传入JaxbDataFormat.Configuration实例。

  • 缩进需同时设marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true)marshaller.setProperty(Marshaller.JAXB_ENCODING, "UTF-8")
  • 若强制GBK输出,除了设JAXB_ENCODING,还必须在to("file:output?charset=GBK")里显式声明charset参数,否则文件内容仍是UTF-8字节
  • 避免在marshal()后接convertBodyTo(String.class)再处理——这会触发两次序列化,中间XML可能被意外转义
JaxbDataFormat jaxb = new JaxbDataFormat("com.example.invoice");
jaxb.setConfiguration(new JaxbDataFormat.Configuration() {{
    setEncoding("GBK");
    setFormattedOutput(true);
}});
from("direct:invoice")
  .marshal(jaxb)
  .to("file:output?charset=GBK");

遇到javax.xml.bind.UnmarshalException: unexpected element

这是最典型的JAXB反序列化失败,根本原因几乎都是XML根元素名与预期不符。常见于:SOAP响应带soap:Envelope外壳、REST API返回<response><data>...</data></response>嵌套、或命名空间URI拼写差一个字符。

酒店管理系统项目源码(三层开发)
酒店管理系统项目源码(三层开发)

系统采用VS2008+Sql2005开发适用于中小型的酒店管理,全部采用三层架构,ASP.NET开发,运用CSS加DIV的界面布局,完整的源代码和数据库设计,是你不可多得的参考资料。 有客房管理、房间类型管理、入住和退房管理等简单功能HotelManager为网站目录DB_51aspx下为Sql2005数据库,附加即可(Sql2000格式数据库转换后稍后发布)

下载

不要急着改POJO——先用log拦截原始XML,确认实际结构。Camel的streamCaching必须开启,否则logunmarshal会报Stream closed

  • 若只是外层包装,用removeHeaders("Camel*") + setBody(simple("${body.replaceAll('^.+<data>','').replaceAll('</data>.+$','')}"))临时剥离(仅调试用)
  • 若含SOAP外壳,优先用camel-cxf替代裸JAXB;若必须用JAXB,需在contextPath中包含soap包,并让POJO继承org.apache.cxf.binding.soap.SoapMessage
  • 命名空间问题最隐蔽:检查xmlns值是否含尾部斜杠(http://example.com/ vs http://example.com),JAXB认作不同命名空间

复杂XML(混合内容、任意子元素)怎么处理

当XML含<p>Hello <b>world</b>!</p>这类混合内容,或子元素顺序不定、个数不固定(如<item></item>列表长度动态),JAXB原生支持弱。硬套@XmlMixed + List<object></object>会导致类型丢失,后续无法做字段级校验或转换。

此时应切换策略:用camel-domcamel-jacksonxml替代JAXB。后者基于Jackson,对任意结构容忍度高,且能无缝接入ValidationProcessor做JSON Schema式校验。

  • camel-jacksonxml需额外引入jackson-dataformat-xml,且XmlMapper必须禁用FAIL_ON_UNKNOWN_PROPERTIES
  • 混合内容会被转成Map<string object></string>JsonNode,用simple("${body.path('p.b.text()')}")提取文本更灵活
  • 性能比JAXB低15–20%,但开发效率和容错性提升显著,适合非高频核心链路

命名空间、混合内容、编码细节——这三个地方出问题时,错误日志往往不指向真实根源。多打一行log看原始XML,比翻十页文档更快。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

454

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

string转int
string转int

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

990

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

253

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

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

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

1945

2024.04.01

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

24

2026.03.09

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
RunnerGo从入门到精通
RunnerGo从入门到精通

共22课时 | 1.8万人学习

尚学堂Mahout视频教程
尚学堂Mahout视频教程

共18课时 | 3.3万人学习

Linux优化视频教程
Linux优化视频教程

共14课时 | 3.2万人学习

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

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