文章目录
-
- 前言
- 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地址