Apache 孵化器 CXF 团队宣布 2.0.4 版本已经可以下载了。它是 2.0.3 版的补丁(解决了超过 50 个 JIRA 项目)。来自 IONA 的 Dan Kulp 主导了这次发布的大部分工作。
- 不同的绑定,包括 SOAP、REST 和 CORBA。
- WS-*,包括 WS-Addressing、WS-Security、WS-ReliableMessaging 和 WS-Policy
- RESTful Web 服务
- 多种传输(HTTP、JMS、JBI)
- 可插拔数据绑定
- 使用 WSDL 进行契约优先的开发和由 Java 开始进行代码优先的开发。
关键设计考虑包括:
- 从核心代码干净地分离前端,如 JAX-WS。
- 兼具简单性,例如,无需注解就可创建客户端和端点。
- 高性能
- 可嵌入
Dan Diephouse解释:
CXF 是 XFire 最新的光鲜版;它是 2.0 的 XFire。CXF 是 Celtix 和 XFire 社区在 Apache 社区会师后的结合体。
当 Tim O’ Brien问为什么会有人选择 XFire 而非 Axis2 时,Dan 回答道:
我个人的观点是,在 CXF 中有一个大的关注点,Paul [Brown] 称之为,开发者生物工程学。它的 API 相当友好。你可以很容易的重新配置 CXF,无需操心 XML。[CXF 和 Spring 更深入地集成在了一起,包括支持 Spring 2.0 XML 语法。] API 和 Spring 配置彼此对照得很好,这使得人们很容易理解。我们同样是基于 Java 5 的,它带来了更友好的体验。
例如,CXF 提供了几种在运行时动态调用服务的方法,无需从 WSDL 产生客户端。假设你有一个 WSDL,它定义了一个操作“echo”。这个操作接收一个字符串,并输出一个字符串。为此,你可以按照以下方法使用 DynamicClientFactory:
DynamicClientFactory dcf = DynamicClientFactory.newInstance();
Client client = dcf.createClient(“echo.wsdl”);
Object[] res = client.invoke(“echo”, “test echo”);
System.out.println("Echo response: " + res[0]);
Atif Khan 使用 JAX-WS 提供者模型构建了一个 POX(Plain Old XML)服务例子,并使用 Spring 配置它,表示同意:
[CXF] 相当直观,易于使用且功能强大。
Glen Mazza发布了使用CXF 的另一个例子,使用FOP 从国家气象服务获取PDF。
InfoQ 也征询了 Paul Brown 的观点,他正通过一些消费者使用 CXF:
CXF 是一个工业强度的 Web 服务框架。IONA 在这个项目上进行了广泛的投资,在中国有一个开发团队。整个 CXF,和 Axis 这样的其他框架一样,在列集(marshaling)上完成了非常好的工作,将事务时间降低到整个开销的近乎最小值。
具有喜欢 CXF 倾向的人们会构建他们自己的系统。在打包一个可内嵌的 Web 服务组件(如可以加到 Spring 中)问题上,CXF 做得很好。Axis 更多提供的是一个端到端的架构。
查看英文原文: The Apache Incubator CXF team announced the availability of the 2.0.4 release
评论