掌握使用CXF快速开发webservice服务和生成client端技能

文章目录

    • 前言
    • 1.安装和配置cxf环境
    • 2.创建一个通过maven管理的java项目并引入相关cxf依赖
    • 3.使用cxf提供的类编写webservice服务端并发布服务
      • 3.1 定义一个webservice服务接口HelloWorld
      • 3.2 编写HelloWorld实现类
      • 3.3 通过JaxWsServerFactoryBean发布webservice服务
      • 3.4 在浏览器中通过发布的地址查看webservice服务是否发布成功
    • 4.通过webservice客户端调用webservice服务
      • 4.1 有webservice服务端接口的jar
      • 4.2 没有webservice服务端接口的jar
        • 4.2.1 执行如下命令:
        • 4.2.2 生成的代码如下:
        • 4.2.3 将代码导入IDEA编辑器(如果没有项目,记得先创建客户端项目,再将代码整合到项目中)
        • 4.2.4 直接执行HelloWorld_HelloWorldPort_Client即可调用webservice服务端
        • 4.2.5 分析一下cxf生成的代码的结构

前言

本文主要通过示例详细介绍了如何使用CXF进行webservice服务服务端的开发和服务发布,以及如何通过CXF为已经发布的webservice服务生成客户端代码,并详细演示了通过生成的客户端代码进行服务的调用,希望对有需要的小伙伴们有所帮助!

1.安装和配置cxf环境

我是直接在cxf官网下载的apache-cxf-3.6.2版本的压缩包,大家直接去官网下载即可,这里需要注意的点是要配置CXF_HOME环境变量并将cxf的bin目录添加到PATH中
在这里插入图片描述

注意: 如果不清楚是否配置成功cxf工具,可以在命令行中直接执行wsdl2java进行验证

在这里插入图片描述

2.创建一个通过maven管理的java项目并引入相关cxf依赖

cxf相关依赖如下(这里我使用的版本较新,为4.0.3)

    <dependency>
      <groupId>org.apache.cxf</groupId>
      <artifactId>cxf-rt-frontend-jaxws</artifactId>
      <version>4.0.3</version>
  </dependency>


  <dependency>
      <groupId>org.apache.cxf</groupId>
      <artifactId>cxf-rt-transports-http</artifactId>
      <version>4.0.3</version>
  </dependency>
  <!-- Jetty is needed if you're using the CXFServlet -->
  <dependency>
      <groupId>org.apache.cxf</groupId>
      <artifactId>cxf-rt-transports-http-jetty</artifactId>
      <version>4.0.3</version>
  </dependency>

3.使用cxf提供的类编写webservice服务端并发布服务

3.1 定义一个webservice服务接口HelloWorld

package server;

import jakarta.jws.WebParam;
import jakarta.jws.WebService;

@WebService
public interface HelloWorld {
String sayHi(@WebParam(name = "text") String text);
}

3.2 编写HelloWorld实现类

package server;

public class HelloWorldImpl implements HelloWorld {

  public String sayHi(String text) {
      return "Hello " + text;
  }
}

3.3 通过JaxWsServerFactoryBean发布webservice服务


package server;

import org.apache.cxf.jaxws.JaxWsServerFactoryBean;

public class Server {

  protected Server() throws Exception {
      System.out.println("Starting Server");
      HelloWorldImpl implementor = new HelloWorldImpl();
      JaxWsServerFactoryBean svrFactory = new JaxWsServerFactoryBean();
      svrFactory.setServiceClass(HelloWorld.class);
      svrFactory.setAddress("http://localhost:9000/helloWorld");
      svrFactory.setServiceBean(implementor);
      svrFactory.create();
  }

  public static void main(String[] args) throws Exception {
      new Server();
      System.out.println("Server ready...");

      Thread.sleep(5 * 60 * 1000);
      System.out.println("Server exiting");
      System.exit(0);
  }
}

3.4 在浏览器中通过发布的地址查看webservice服务是否发布成功

在这里插入图片描述

4.通过webservice客户端调用webservice服务

这里通常有2种方式可以访问webservice服务端

4.1 有webservice服务端接口的jar

如果有webservice服务端接口的jar,那么可以直接通过JaxWsProxyFactoryBean创建代理的方式访问webservice服务

package client;


import org.apache.cxf.ext.logging.LoggingFeature;
import org.apache.cxf.jaxws.JaxWsProxyFactoryBean;
import server.HelloWorld;


public final class Client {

  private Client() {
  }

  public static void main(String[] args) throws Exception {
      JaxWsProxyFactoryBean factory = new JaxWsProxyFactoryBean();
      factory.getFeatures().add(new LoggingFeature());
      factory.setAddress("http://localhost:9000/helloWorld");
      HelloWorld client = factory.create(HelloWorld.class);
      System.out.println(client.sayHi("World"));
  }

}

4.2 没有webservice服务端接口的jar

如果没有webservice服务端接口的jar,可以通过cxf提供的wsdl2java工具生成webservice客户端

4.2.1 执行如下命令:
wsdl2java -p ws.demo.client -d /Users/apple/Documents/idea/jaxws_factory_bean_client/src/main/java/  -client http://localhost:9000/helloWorld?wsdl
(1) -p  指定其wsdl的命名空间,也就是要生成代码的包名.
(2) -d  指定要产生代码所在目录.
(3) -client 生成客户端测试web service的代码.
4.2.2 生成的代码如下:

在这里插入图片描述

4.2.3 将代码导入IDEA编辑器(如果没有项目,记得先创建客户端项目,再将代码整合到项目中)

在这里插入图片描述

4.2.4 直接执行HelloWorld_HelloWorldPort_Client即可调用webservice服务端

在这里插入图片描述

4.2.5 分析一下cxf生成的代码的结构

HelloWorld为webservice服务端定义的webservice服务接口

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

HelloWorld_HelloWorldPort_Client为调用webservice客户端,可以直接运行调用webservice服务端

在这里插入图片描述

如果调用的wsdl地址有变动,可以修改HelloWorldService中的WSDL_LOCATION值为新的wsdl地址

在这里插入图片描述