Apache孵化器CXF团队发布2.0.4版

Apache孵化器CXF团队宣布2.0.4版本已经可以下载了。它是2.0.3版的补丁(解决了超过50个JIRA项目)。来自IONA的Dan Kulp主导了这次发布的大部分工作。

CXF是一个特性齐全的开源 Web服务框架,它支持:

  • 不同的绑定,包括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

你可能感兴趣的:(Apache孵化器CXF团队发布2.0.4版)