掌握使用CXF快速开发webservice服务和生成client端技能
时间:2024-04-26 15:25:25 来源:网络cs 作者:利杜鹃 栏目:跨境学堂 阅读:
文章目录
前言1.安装和配置cxf环境2.创建一个通过maven管理的java项目并引入相关cxf依赖3.使用cxf提供的类编写webservice服务端并发布服务3.1 定义一个webservice服务接口HelloWorld3.2 编写HelloWorld实现类3.3 通过JaxWsServerFactoryBean发布webservice服务3.4 在浏览器中通过发布的地址查看webservice服务是否发布成功 4.通过webservice客户端调用webservice服务4.1 有webservice服务端接口的jar4.2 没有webservice服务端接口的jar4.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;@WebServicepublic 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地址
本文链接:https://www.kjpai.cn/xuetang/2024-04-26/162552.html,文章来源:网络cs,作者:利杜鹃,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!
下一篇:返回列表