`
liugang594
  • 浏览: 991275 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

使用CXF和camel-cxf调用webservice

 
阅读更多

CXF是什么

Apache CXF 是一个开源的、全功能的WebService框架,它提供了一套工具和API来帮助开发和构建WebService,像 JAX-WS 和 JAX-RS。它也支持许多WebService标准,例如:

和许多其他的特性。[更多的请参考 http://en.wikipedia.org/wiki/Apache_CXF]

demo.wsdl 是本文中使用的示例wsdl文件.

使用CXF调用WebService

每个WebService服务都需要提供一套用于外部调用的接口,也需要提供对应于这些接口调用的输入输出数据格式。用于规范这些接口和消息格式定义的标准就是 WSDL 。在本节里,将讨论如何使用CXF 来开发一个基于某个WSDL的WebService客户端。 (这里假设使用的传输协议为 HTTP,更多的可以参考本博客里的关于CXF的介绍的文章).

本质上,每个基于 HTTP 的WebService服务都等价于一个接收 HTTP-POST 请求的HTTP服务,为了调用这个服务,用户只需要知道如何构造一个期望的HTTP POST请求格式,例如:

 

POST http://localhost:8040/services/WebService HTTP/1.1
Accept-Encoding: gzip,deflate
Content-Type: text/xml;charset=UTF-8
SOAPAction: "http://www.talend.org/service/WebServiceOperation1"
Content-Length: 307
Host: localhost:8040
Connection: Keep-Alive
 
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ser="http://www.talend.org/service/">
   <soapenv:Header/>
   <soapenv:Body>
      <ser:WebServiceOperationRequest1>
         <in>Hello</in>
      </ser:WebServiceOperationRequest1>
   </soapenv:Body>
</soapenv:Envelope>
 可以使用Java HTTP API 发送以上请求:

 

 

//request content
String content = "<soapenv:Envelope"
        + " xmlns:soapenv=\"http://schemas.xmlsoap.org/soap/envelope/\""
        + " xmlns:ser=\"http://www.talend.org/service/\">"
        + "<soapenv:Body><ser:WebServiceOperationRequest1><in>Hello</in>"
        + "</ser:WebServiceOperationRequest1></soapenv:Body>"
        + "</soapenv:Envelope>";
 
//service url
URL url = new URL("http://localhost:8040/services/WebService");
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
 
//set soapaction
connection.addRequestProperty("SOAPAction",
        "http://www.talend.org/service/WebServiceOperation1");
connection.setDoOutput(true);
connection.setDoInput(true);
 
//send out request
OutputStream os = connection.getOutputStream();
os.write(content.getBytes());
os.flush();
 
//read response and print out
InputStream is = connection.getInputStream();
int available = is.available();
byte[] response = new byte[available];
is.read(response);
System.out.println(new String(response));
 
os.close();
is.close();

 

从以上代码里可以看出,为了使得调用成功,我们需要关心从请求信息到连接信息的几乎每个细节。因此这里,我们将介绍如果使用CXF 来简化请求,从而让用户可以只关注业务逻辑部分,再底层细节由CXF 处理。

CXF 提供了好几种调用WebService的方法,详细的可以参考本博客里的相关文章。这里就介绍两种:Provider-Dispatch 和 JAX-WS

 Provider-Dispatch

Provider-Dispatch 是一种类似于 Java HTTP 的方式,好处就是灵活、方便、强大,缺点就是和Java HTTP 一样,用户需要知道如何构建一个合格的消息。更多的可以看 http://liugang594.iteye.com/blog/1964510  。

JAX-WS

JAX-WS 是 Java API for XML Web Services 的简称,它是用于创建WebService的Java API,它定义了一个用于Java-WSDL映射的标准,例如WSDL接口如何绑定到Java方法,以及SOAP消息如何匹配到方法的参数等。

为了简化 WSDL 和 Java的映射, CXF 提供了一些工具和API用于Java和WSDL之间的转换,这里只展示如何从WSDL转成Java.

WSDL2Java 命令行

CXF 提供了一个 wsdl2java 命令行工具用于从 WSDL 转换到 Java,有很多可用的选项,以下列出了主要的几个选项:[更多的可以访问 https://cxf.apache.org/docs/wsdl-to-java.html ]:

Option

Interpretation

-p [ wsdl-namespace= ] PackageName

Specifies zero, or more, package names to use for the generated code. Optionally specifies the WSDL namespace to package name mapping.

-d output-directory

Specifies the directory into which the generated code files are written.

wsdlurl

The path and name of the WSDL file to use in generating the code.

例如要生成对应于以上 demo.wsdl的代码,可以使用以下命令:

 

wsdl2java -p org.talend.esb.camel.cxf -d output  demo.wsdl
 

 

完成以后就可以看到生成的代码列表:

更进一步的,后 6 类分别对应于WSDL中的 Service(s), DataTypes 和 PortType(s)从Java对象到 WSDL 和 XML 元素的映射关系由annotation决定。这里,生成的代码里有两类annotation:

JAX-WS annotations

这类annotation主要用于Java和WSDL之间的映射These annotations are mainly used to map a java class to Web Service.

Annotation Description
WebService Every Class who wants to be published as a Web Service should be annotated by this annotation
SOAPBinding Define the SOAP Binding style of this service
WebResult Define the mapping from method return object to WSDL operation output
WebMethod Define the mapping between Java method to WSDL operation
WebParam Define the mapping between method argument to WSDL operation Input

访问 https://jax-ws.java.net/jax-ws-ea3/docs/annotations.html 以了解每个annotation的更多细节。

JAXB Annotations

JAX-WS annotations用于java到 WSDL之间的映射,而JAXB annotation则是用于Java对象到XML结构的映射。 JAXB 是 CXF 默认的数据映射方式,用户也可以使用以下参数指定其他的映射方式:

-db

下面是生成代码里用到的 JAXB 相关的annotation说明:

Annotation Description
XmlAccessorType Used on a class to specify which members will be mapped to xml, for example FIELDPUBLIC
XmlElement Use to indicate the member will be mapped to an xml element
XmlType Used on a class to specify the generated xml type of this class
XmlRootElement Used to indicate it can be a root element of xml

有了这些类后,可以很容易的用他们来调用WebService了:

//create service instance
Service service = Service.create(new URL("http://localhost:8040/services/WebService?wsdl"), new QName("http://www.talend.org/service/", "WebService"));
//create port from service
WebServicePortType port = service.getPort(WebServicePortType.class);
//input parameter
WebServiceOperationRequest1 operationRequest1 = new WebServiceOperationRequest1();
operationRequest1.setIn("World");
//invoke, and get response
WebServiceOperationResponse1 operationResponse1 = port.webServiceOperation1(operationRequest1);
//print out the result
System.out.println(operationResponse1.getOut());

只需要知道wsdl的路径和service的qname,其他的都是普通的Java对象。

注意:返回值也是一个对象,而不是普通的XML内容,可以使用以下代码进行转换:

Object to XML
1
2
3
JAXBContext context = JAXBContext.newInstance(WebServiceOperationResponse1.class);
Marshaller marshaller = context.createMarshaller();
marshaller.marshal(operationResponse1, System.out);

 

WSDL2Java API 

除了命令行,也可使用代码来进行wsdl到java的转换:

WSDLToJava wsdlToJava = new WSDLToJava(new String[]{"-p", "org.talend.esb.camel.cxf", "-d", "output",  "demo.wsdl"});
wsdlToJava.run(new ToolContext());

使用camel-cxf调用WebService

camel-cxf 组件是基于 CXF的,它提供了在Camel中访问WebService的能力。 

URI 格式

 

cxf:bean:cxfEndpoint[?options]
当 cxfEndpoint 代表一个已经注册了的Bean的ID。使用这种格式的URI,节点的大部分内容在Bean里定义。

 

或者:

 

cxf://someAddress[?options]
 这里 someAddress 指定了 CXF 端点的地址。使用这种格式的URI,节点的大部分定义是由选项指定的。本文里只讨论这种格式。

 

选项

camel-cxf组件提供了很多可用的选项,对于consumer端,大部分有用的选项都在下表中:[ 更多的请看 http://camel.apache.org/cxf.html ]:

 

Name

Required

Description

wsdlURL

No

The location of the WSDL. It is obtained from endpoint address by default. 

Examplefile://local/wsdl/hello.wsdl or wsdl/hello.wsdl

serviceClass

Yes

The name of the SEI (Service Endpoint Interface) class. This class can have, but does not require, JSR181 annotations. 
This option is only required by POJO mode. If the wsdlURL option is provided, serviceClass is not required for PAYLOAD and MESSAGE mode. When wsdlURL option is used without serviceClass, the serviceName and portName (endpointName for Spring configuration) options MUST be provided. It is possible to use # notation to reference a serviceClass object instance from the registry. E.g. serviceClass=#beanName. The serviceClass for a CXF producer (that is, the to endpoint) should be a Java interface.
Since 2.8, it is possible to omit both wsdlURL and serviceClass options for PAYLOAD and MESSAGE mode. When they are omitted, arbitrary XML elements can be put in CxfPayload's body in PAYLOAD mode to facilitate CXF Dispatch Mode. 

Please be advised that the referenced object cannot be a Proxy (Spring AOP Proxy is OK) as it relies onObject.getClass().getName() method for non Spring AOP Proxy. 

Exampleorg.apache.camel.Hello

serviceName

No

The service name this service is implementing, it maps to the wsdl:service@name

Required for camel-cxf consumer since camel-2.2.0 or if more than one serviceName is present in WSDL. 

Example: {http:­//org.apache.camel}ServiceName

portName

No

The port name this service is implementing, it maps to the wsdl:port@name

Required for camel-cxf consumer since camel-2.2.0 or if more than one portName is present under serviceName

Example: {http:­//org.apache.camel}PortName

dataFormat

No

The data type messages supported by the CXF endpoint. 

DefaultPOJO 
ExamplePOJOPAYLOADRAW

DataFormat的描述如下:

DataFormat

Description

POJO

POJOs (Plain old Java objects) are the Java parameters to the method being invoked on the target server. Both Protocol and Logical JAX-WS handlers are supported.

PAYLOAD

PAYLOAD is the message payload (the contents of the soap:body) after message configuration in the CXF endpoint is applied. Only Protocol JAX-WS handler is supported. Logical JAX-WS handler is not supported.

RAW

RAW is the raw message that is received from the transport layer. It is not suppose to touch or change Stream, some of the CXF interceptor will be removed if you are using this kind of DataFormat so you can't see any soap headers after the camel-cxf consumer and JAX-WS handler is not supported.

CXF_MESSAGE

New in Camel 2.8.2CXF_MESSAGE allows for invoking the full capabilities of CXF interceptors by converting the message from the transport layer into a raw SOAP message

DataFormats

RAW

camel-cxf支持4种DataFormat,下面将显示每种DataFormat的特点与不同:

 

from("timer:foo?repeatCount=1")       
        .setBody(constant(content))             //set request body
        .to("cxf:"
                + "http://localhost:8040/services/WebService" //service address
                + "?"
                + "wsdlURL=http://localhost:8040/services/WebService?wsdl"    //wsdl url
                + "&"
                + "dataFormat=RAW"        //dataformat type
            )
        .convertBodyTo(String.class)
        .to("log:output");

以上代码示例的作用和最上的Java HTTP API效果是一样的,这里用的 dataFormat 为 RAW,请求内容为:

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
        xmlns:ser="http://www.talend.org/service/">
    <soapenv:Body>
        <ser:WebServiceOperationRequest1>
            <in>Hello</in>
        </ser:WebServiceOperationRequest1>
    </soapenv:Body>
</soapenv:Envelope>

 

对于RAW,可以看出,整个soap envelope的结构都需要指定,返回值也是一个完整的Envelope的结构:

 

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
    <soap:Body>
        <tns:WebServiceOperationResponse1 xmlns:tns="http://www.talend.org/service/">
            <out>Hello</out>
        </tns:WebServiceOperationResponse1>
    </soap:Body>
</soap:Envelope>

PAYLOAD

不同的DataFormat,请求内容的格式也是不一样,例如上例中,把RAW 换成 PAYLOAD,则内容需要指定为:

<ser:WebServiceOperationRequest1 xmlns:ser="http://www.talend.org/service/">
    <in>Hello</in>
</ser:WebServiceOperationRequest1>

只有soap body节点内的内容需要指定,返回的结果也是只有soap body内的内容:

 

<tns:WebServiceOperationResponse1 xmlns:tns="http://www.talend.org/service/">
    <out>Hello</out>
</tns:WebServiceOperationResponse1>

 

CXF_MESSAGE

CXF_MESSAGE 类似于 RAW,它也要求整个soap envelope的结构,但是内容对象需要是一个 javax.xml.transform.Source 实例,因此需要先把内容转成一个 javax.xml.transform.Source 对象:

 

from("timer:foo?repeatCount=1")       
        .setBody(constant(content))             //set request body
        .convertBodyTo(DOMSource.class)         //convert content to a DOMSource instance
        .to("cxf:"
                + "http://localhost:8040/services/WebService" //service address
                + "?"
                + "wsdlURL=http://localhost:8040/services/WebService?wsdl"    //wsdl url
                + "&"
                + "dataFormat=CXF_MESSAGE"        //dataformat type
            )
        .convertBodyTo(String.class)
        .to("log:output");
可以看到除了把 RAW 变成 CXF_MESSAGE,还添加了 ".convertBodyTo(DOMSource.class)" 用于转换 "setBody(constant(content))" 里的内容,否则会得到异常,返回的结果和 RAW一样:

 

 

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
    <SOAP-ENV:Header xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"/>
    <soap:Body>
        <tns:WebServiceOperationResponse1 xmlns:tns="http://www.talend.org/service/">
            <out>Hello</out>
        </tns:WebServiceOperationResponse1>
    </soap:Body>
</soap:Envelope>

除了请求内容实例外,RAW 和 CXF_MESSAGE 主要区别在于:CXF_MESSAGE 拥有完全的 CXF interceptor功能,而他们中的一些则不能用在 RAW 类型上。

 POJO

POJO 意味着请求的对象内容是一个普通的java对象,而不是xml结构的内容。camel-cxf 在底下会把这个对象转换成一个xml结构的内容,这点像我们之上JAX-WS一节介绍的内容。例如重用以上生成的 WebServiceOperationRequest1 类去创建请求:

from("timer:foo?repeatCount=1")
        .process(new Processor() {      //use processor to set body
            public void process(Exchange arg0) throws Exception {
                WebServiceOperationRequest1 request1 = new WebServiceOperationRequest1();
                request1.setIn("Hello1");
                arg0.getIn().setBody(request1);
            }
        })
        .to("cxf:"
                + "http://localhost:8040/services/WebService" // service address
                + "?"
                + "wsdlURL=http://localhost:8040/services/WebService?wsdl" // wsdl url
                + "&"
                + "serviceClass=org.talend.esb.camel.cxf.WebServicePortType" //serviceClass
                + "&" + "dataFormat=POJO" // dataformat type
        ).to("log:output");

和之前的代码比较,有一些变化:

  1. setBody() 换成一个 Processor
    根据我们的讨论,一个 POJO 对象需要设置成body,因些这里使用 Processor 去设置body 
  2. 选项 serviceClass 需要被指定
    当使用POJO时,需要指定 serviceClass 这个选项用来指定Service类。

输出对象不能被转成一个string,因此这里直接打印出来:

 

Exchange[ExchangePattern: InOnly, BodyType: org.apache.cxf.message.MessageContentsList, Body: [org.talend.esb.camel.cxf.WebServiceOperationResponse1@19aa5882]]

可以看出,返回的值是一个 org.talend.esb.camel.cxf.WebServiceOperationResponse1 实例。

Headers

有一些headers可以用来影响camel-cxf的行为,例如如果没有指定operation,那么在WSDL中定义的第一个会被使用到,例如在我们的示例 demo.wsdl 里有两个operation,总是会使用第一个。如果检测一下camel-cxf可用的选项,有两个和operation相关的:

Name

Required

Description

defaultOperationName

No

New in 2.4, this option will set the default operationName that will be used by the CxfProducer which invokes the remote service. 

Defaultnull 
ExampledefaultOperationName=greetMe

defaultOperationNamespace

No

New in 2.4. This option will set the default operationNamespace that will be used by the CxfProducer which invokes the remote service. 

Defaultnull 
ExampledefaultOperationNamespace=http://apache.org/hello_world_soap_http

可以指定缺省值,而不是总使用第一个。除了选项,有两个header可以用来指定operation,一旦指定,缺省值就会被覆盖:

Header Name

Description

operationName

Specify the operation name which you are calling

operationNamespace

Specify the operation namespace which you are calling

另外,默认 SOAPAction 的值是空的,可以通过指定header的方式指定它: setHeader("SOAPAction", constant("http://www.talend.org/service/WebServiceOperation2")) ,这个值会作为HTTP的头发送。实际上所有自定义的头都会作为HTTP的头发送,例如:

 

setHeader("CorrelationID", constant("ADLKLWE-SADFA-EWEFFSAD_SADFASLFKAF"))

 

在传输时会变成:CorrelationID: ADLKLWE-SADFA-EWEFFSAD_SADFASLFKAF

Interceptor & Feature

当使用 CXF两个重要的部分需要提到: Interceptor and Feature。以下是从CXF网站上拷过来的:

Feature: in CXF is a way of adding capabilities to a Server, Client or Bus. For example, you could add the ability to log messages for each of these objects, by configuring them with a LoggingFeature. To implement a Feature, you must subclass AbstractFeature. //cxf.apache.org/docs/features.html

 

Interceptor: the fundamental processing unit inside CXF. When a service is invoked, an InterceptorChain is created and invoked. Each interceptor gets a chance to do what they want with the message. This can include reading it, transforming it, processing headers, validating the message, etc.

 camel-cxf中,我们通过CxfEndpoint 来安装 features 和 Interceptors,例如安装loggingFeature:

//create Endpoint
Endpoint cxfEndpoint = endpoint("cxf:"
                + "http://localhost:8040/services/WebService" // service address
                + "?"
                + "wsdlURL=http://localhost:8040/services/WebService?wsdl" // wsdl url
                + "&" + "dataFormat=PAYLOAD" // dataformat type
            );
 
//add feature
((CxfEndpoint)cxfEndpoint).getFeatures().add(new LoggingFeature());
 
//create route
from("timer:foo?repeatCount=1").setBody(constant(content))    // set request body
        .to(cxfEndpoint);

LoggingFeature会记录在client端和server端传输的输入输出消息。我们也可以使用Interceptors来达到同样的功能,如果看LoggingFeature的源码就会发现,在底层,它使用了LoggingInInterceptor 和 LoggingOutInterceptor,这就意味着我们可以用他们替换 LoggingFeature:

//create Endpoint
Endpoint cxfEndpoint = endpoint("cxf:"
                + "http://localhost:8040/services/WebService" // service address
                + "?"
                + "wsdlURL=http://localhost:8040/services/WebService?wsdl" // wsdl url
                + "&" + "dataFormat=PAYLOAD" // dataformat type
            );
 
//add Interceptor
((CxfEndpoint)cxfEndpoint).getInInterceptors().add(new LoggingInInterceptor());
((CxfEndpoint)cxfEndpoint).getOutInterceptors().add(new LoggingOutInterceptor());
 
 
//create route
from("timer:foo?repeatCount=1").setBody(constant(content))    // set request body
        .to(cxfEndpoint);

结果和使用Feature是一样的。

  • demo.zip (710 Bytes)
  • 下载次数: 270
分享到:
评论
1 楼 shirounet 2016-01-29  
你好,文中
//create Endpoint 
Endpoint cxfEndpoint = endpoint("cxf:"
这句代码中,endpoint方法是自定义的方法么?

相关推荐

    camel-cxf调用和发布webservice例子

    用camel-cxf调用webservice和发布一个webservice接口例子,首先启动QueryServiceMain主函数启动webservice接口,然后启动测试类TestWebservice。例子主要是实现java代码实现camel调用webservice接口

    05-ApacheCamel-CXF-WebService

    在项目中,"05-ApacheCamel-CXF-WebService-Client"这部分内容可能是客户端的应用,用于调用由Apache CXF和Camel服务端提供的Web服务。客户端通常包括CXF的客户端API配置,以及Camel的路由定义,用于发起服务请求并...

    servicemix 7安装使用及camel-cxf代理webservice

    【标题】:“servicemix 7安装使用及camel-cxf代理webservice”涉及的知识点主要涵盖Apache ServiceMix 7的安装配置、Apache Camel和Apache CXF的集成使用,以及如何利用它们来代理Web服务。 Apache ServiceMix是...

    Apache CXF2+Spring2.5轻松实现WebService

    客户端可以通过WSDL文档来发现和调用服务。 在实际项目中,可能还需要处理安全、事务、异常处理等问题。Apache CXF和Spring提供了丰富的扩展点,可以集成如Spring Security来控制访问权限,使用Spring AOP来处理...

    CXF方式开发和部署webservice应用

    - **拦截器**: 可以使用CXF的拦截器机制,对服务调用进行拦截,实现日志记录、性能监控等功能。 - **数据绑定**: 支持JAXB和XMLBeans等多种数据绑定技术,用于对象与XML之间的转换。 综上所述,CXF为开发者提供了...

    使用cxf发布的webservice服务

    总的来说,“使用CXF发布的WebService服务”涉及到以下几个关键步骤:定义服务接口和实现,配置CXF服务端点,部署服务,以及生成和使用客户端代理。通过这个“employeeServiceForCxf”示例,初学者可以清晰地了解到...

    servicemix 3安装及cxf-bc组件代理webservice服务

    在本文中,我们将深入探讨Apache Servicemix 3的安装过程以及如何使用CXF-Bundle Component来代理WebService服务。Apache Servicemix是企业级的服务导向架构(SOA)平台,基于OSGi容器,支持多种标准如JBI、Spring、...

    apache-cxf-2.3.3.zip

    CXF的全称是"Camel XFire",起初是两个独立项目(Camel和XFire)的合并,后来演变为现在的Apache CXF。它在Web服务领域扮演着重要的角色,提供了服务端和客户端的实现,使得开发者能够轻松地创建和消费Web服务。 在...

    使用DOS 生成webservice 客户端代码 (CXF)

    CXF是"Camel XFire"和"CXF"的结合,它源自两个不同的项目,致力于简化Web服务的开发。CXF不仅支持传统的SOAP Web服务,还支持RESTful API,使得开发者可以选择最适合他们需求的通信模式。 描述中提到了几个ZIP文件...

    CXF生成ws客户端代码

    本文将详细介绍如何使用CXF的“wsdl2java”工具来生成Webservice客户端代码。 #### 二、基础知识 ##### 1. WSDL(Web Service Description Language) WSDL是一种用于描述Web服务的标准格式。它定义了服务的抽象...

    cxf+spring+hibernate集成整合jar包

    在提供的"压缩包子文件的文件名称列表"中,"cxf webservice全jar包"包含了CXF所需的全部库,这些jar包将用于构建和运行CXF Web服务。开发者需要将这些库与Spring和Hibernate的库合并到项目的类路径中,以完成完整的...

    cxf发布RestFul接口。 maven

    CXF(Camel XFire)是一个强大的服务框架,它允许开发者以多种方式创建和部署Web服务,包括基于Java API for RESTful Web Services (JAX-RS)的RESTful接口和基于Java API for XML Web Services (JAX-WS)的SOAP服务。...

    cxf 开发web services apache 官方文档

    CXF(Camel and XFire)是 Apache 软件基金会提供的一款开源框架,用于构建和消费基于 SOAP 和 RESTful 协议的 Web 服务。它支持多种协议和技术栈,包括 SOAP、XML、REST 等,并且能够与 Spring 框架很好地集成,...

    基于spring3.0的cxf发布webservice+client的

    本篇文章将围绕“基于Spring 3.0的CXF发布Web Service及客户端”的主题展开,详细介绍如何利用这两个强大的工具来实现服务的发布和调用。 首先,我们需要理解Spring 3.0的关键特性。Spring 3.0引入了更多的模块和...

    CXF开发文档

    Apache CXF(Camel XFire)是一款开源的服务框架,它提供了用于构建和消费RESTful及SOAP Web服务的API。CXF框架支持多种协议和技术栈,如HTTP、HTTPS、JAX-WS、JAX-RS等,旨在简化Web服务的开发过程。CXF不仅支持...

    CXF服务端和客户端 应用开发指南

    CXF(Camel XFire Framework)是Apache软件基金会的一个开源项目,旨在简化Web Services的开发过程,提供了一个强大的框架来创建和消费SOAP和RESTful Web Services。CXF不仅支持多种绑定类型,如SOAP/HTTP、SOAP/JMS...

    Apache CXF之helloworld

    这个"Apache CXF之helloworld"示例旨在帮助初学者理解如何使用CXF来创建和消费简单的Web服务。CXF允许开发者通过Java API(如JAX-WS和JAX-RS)来定义服务接口,并自动将其转换为HTTP服务。 首先,我们来了解一下CXF...

    FuseDirectVMExample:Camel CXF 直接虚拟机示例

    熔断 direct-vm 示例该项目包含两个 OSGI 包,它们协同工作以展示如何在 Apache Camel 中使用 direct-vm 端点。 两个包都需要部署在 Fuse 容器中,项目才能成功运行。项目详情:流:exampleHello CXF Webservice -&gt; ...

Global site tag (gtag.js) - Google Analytics