`

Axis2开发WebService客户端 的3种方式

 
阅读更多

第一RPC方式,不生成客户端代码

第二,document方式,不生成客户端代码

第三,用wsdl2java工具,生成客户端方式调用

Java代码  收藏代码
  1. package samples.quickstart.client;  
  2.   
  3. import javax.xml.namespace.QName;  
  4. import org.apache.axiom.om.OMAbstractFactory;  
  5. import org.apache.axiom.om.OMElement;  
  6. import org.apache.axiom.om.OMFactory;  
  7. import org.apache.axiom.om.OMNamespace;  
  8. import org.apache.axis2.AxisFault;  
  9. import org.apache.axis2.addressing.EndpointReference;  
  10. import org.apache.axis2.client.Options;  
  11. import org.apache.axis2.client.ServiceClient;  
  12. import org.apache.axis2.rpc.client.RPCServiceClient;  
  13. import samples.quickstart.StockQuoteServiceStub;  
  14. import samples.quickstart.xsd.GetPrice;  
  15. import samples.quickstart.xsd.GetPriceResponse;  
  16.   
  17. public class StockQuoteClient {  
  18.   
  19.   /** 
  20.    * 方法一: 
  21.    * 应用rpc的方式调用 这种方式就等于远程调用, 
  22.    * 即通过url定位告诉远程服务器,告知方法名称,参数等, 调用远程服务,得到结果。 
  23.    * 使用 org.apache.axis2.rpc.client.RPCServiceClient类调用WebService 
  24.    * 
  25.     【注】: 
  26.      
  27.         如果被调用的WebService方法有返回值 应使用 invokeBlocking 方法 该方法有三个参数 
  28.           第一个参数的类型是QName对象,表示要调用的方法名; 
  29.           第二个参数表示要调用的WebService方法的参数值,参数类型为Object[]; 
  30.             当方法没有参数时,invokeBlocking方法的第二个参数值不能是null,而要使用new Object[]{}。 
  31.           第三个参数表示WebService方法的 返回值类型的Class对象,参数类型为Class[]。 
  32.          
  33.          
  34.         如果被调用的WebService方法没有返回值 应使用 invokeRobust 方法 
  35.           该方法只有两个参数,它们的含义与invokeBlocking方法的前两个参数的含义相同。 
  36.  
  37.         在创建QName对象时,QName类的构造方法的第一个参数表示WSDL文件的命名空间名, 
  38.         也就是 <wsdl:definitions>元素的targetNamespace属性值。 
  39.    * 
  40.    */  
  41.   public static void testRPCClient() {  
  42.     try {  
  43.       // axis1 服务端  
  44. // String url = "http://localhost:8080/StockQuote/services/StockQuoteServiceSOAP11port?wsdl";  
  45.       // axis2 服务端  
  46.       String url = "http://localhost:8080/axis2ServerDemo/services/StockQuoteService?wsdl";  
  47.   
  48.       // 使用RPC方式调用WebService  
  49.       RPCServiceClient serviceClient = new RPCServiceClient();  
  50.       // 指定调用WebService的URL  
  51.       EndpointReference targetEPR = new EndpointReference(url);  
  52.       Options options = serviceClient.getOptions();  
  53.       //确定目标服务地址  
  54.       options.setTo(targetEPR);  
  55.       //确定调用方法  
  56.       options.setAction("urn:getPrice");  
  57.   
  58.       /** 
  59.        * 指定要调用的getPrice方法及WSDL文件的命名空间 
  60.        * 如果 webservice 服务端由axis2编写 
  61.        * 命名空间 不一致导致的问题 
  62.        * org.apache.axis2.AxisFault: java.lang.RuntimeException: Unexpected subelement arg0 
  63.        */  
  64.       QName qname = new QName("http://quickstart.samples/xsd""getPrice");  
  65.       // 指定getPrice方法的参数值  
  66.       Object[] parameters = new Object[] { "13" };  
  67.         
  68.       // 指定getPrice方法返回值的数据类型的Class对象  
  69.       Class[] returnTypes = new Class[] { double.class };  
  70.   
  71.       // 调用方法一 传递参数,调用服务,获取服务返回结果集  
  72.       OMElement element = serviceClient.invokeBlocking(qname, parameters);  
  73.       //值得注意的是,返回结果就是一段由OMElement对象封装的xml字符串。  
  74.       //我们可以对之灵活应用,下面我取第一个元素值,并打印之。因为调用的方法返回一个结果  
  75.       String result = element.getFirstElement().getText();  
  76.       System.out.println(result);  
  77.   
  78.       // 调用方法二 getPrice方法并输出该方法的返回值  
  79.       Object[] response = serviceClient.invokeBlocking(qname, parameters, returnTypes);  
  80.       // String r = (String) response[0];  
  81.       Double r = (Double) response[0];  
  82.       System.out.println(r);  
  83.   
  84.     } catch (AxisFault e) {  
  85.       e.printStackTrace();  
  86.     }  
  87.   }  
  88.   
  89.   /** 
  90.    * 方法二: 应用document方式调用 
  91.    * 用ducument方式应用现对繁琐而灵活。现在用的比较多。因为真正摆脱了我们不想要的耦合 
  92.    */  
  93.   public static void testDocument() {  
  94.     try {  
  95.       // String url = "http://localhost:8080/axis2ServerDemo/services/StockQuoteService";  
  96.       String url = "http://localhost:8080/StockQuote/services/StockQuoteServiceSOAP11port?wsdl";  
  97.   
  98.       Options options = new Options();  
  99.       // 指定调用WebService的URL  
  100.       EndpointReference targetEPR = new EndpointReference(url);  
  101.       options.setTo(targetEPR);  
  102.       // options.setAction("urn:getPrice");  
  103.   
  104.       ServiceClient sender = new ServiceClient();  
  105.       sender.setOptions(options);  
  106.         
  107.         
  108.       OMFactory fac = OMAbstractFactory.getOMFactory();  
  109.       String tns = "http://quickstart.samples/";  
  110.       // 命名空间,有时命名空间不增加没事,不过最好加上,因为有时有事,你懂的  
  111.       OMNamespace omNs = fac.createOMNamespace(tns, "");  
  112.   
  113.       OMElement method = fac.createOMElement("getPrice", omNs);  
  114.       OMElement symbol = fac.createOMElement("symbol", omNs);  
  115.       // symbol.setText("1");  
  116.       symbol.addChild(fac.createOMText(symbol, "Axis2 Echo String "));  
  117.       method.addChild(symbol);  
  118.       method.build();  
  119.         
  120.       OMElement result = sender.sendReceive(method);  
  121.   
  122.       System.out.println(result);  
  123.   
  124.     } catch (AxisFault axisFault) {  
  125.       axisFault.printStackTrace();  
  126.     }  
  127.   }  
  128.   
  129.  /** 
  130.   * 为SOAP Header构造验证信息, 
  131.   * 如果你的服务端是没有验证的,那么你不用在Header中增加验证信息 
  132.   * 
  133.   * @param serviceClient 
  134.   * @param tns 命名空间 
  135.   * @param user 
  136.   * @param passwrod 
  137.   */  
  138.   public void addValidation(ServiceClient serviceClient, String tns , String user, String passwrod) {  
  139.     OMFactory fac = OMAbstractFactory.getOMFactory();  
  140.     OMNamespace omNs = fac.createOMNamespace(tns, "nsl");  
  141.     OMElement header = fac.createOMElement("AuthenticationToken", omNs);  
  142.     OMElement ome_user = fac.createOMElement("Username", omNs);  
  143.     OMElement ome_pass = fac.createOMElement("Password", omNs);  
  144.       
  145.     ome_user.setText(user);  
  146.     ome_pass.setText(passwrod);  
  147.       
  148.     header.addChild(ome_user);  
  149.     header.addChild(ome_pass);  
  150.   
  151.     serviceClient.addHeader(header);  
  152.   }  
  153.   
  154.     
  155.   /** 
  156.    * 方法三:利用axis2插件生成客户端方式调用 
  157.    * 
  158.    */  
  159.   public static void testCodeClient() {  
  160.     try {  
  161.       String url = "http://localhost:8080/axis2ServerDemo/services/StockQuoteService";  
  162.       StockQuoteServiceStub stub = new StockQuoteServiceStub(url);  
  163.       GetPrice request = new GetPrice();  
  164.       request.setSymbol("ABCD");  
  165.       GetPriceResponse response = stub.getPrice(request);  
  166.       System.out.println(response.get_return());  
  167.     } catch (org.apache.axis2.AxisFault e) {  
  168.       e.printStackTrace();  
  169.     } catch (java.rmi.RemoteException e) {  
  170.       e.printStackTrace();  
  171.     }  
  172.   
  173.   }  
  174.   
  175.   public static void main(String[] args) {  
  176.      StockQuoteClient.testRPCClient();  
  177. // StockQuoteClient.testDocument();  
  178.     // StockQuoteClient.testCodeClient();  
  179.   
  180.   }  
  181. }  

 

wsdl2java 用于根据WSDL生成相应的服务端和客户端代码的生成工具。
命令行格式为:WSDL2Java [options] -uri <url or path> : A url or path to a WSDL

例如:

wsdl2java -uri http://localhost:8080/cxfService_0617/services/Hellows?wsdl -s -o build\client

 

其中常用的options具体如下:
-o <path> : 指定生成代码的输出路径
-a : 生成异步模式的代码
-s : 生成同步模式的代码
-p <pkg> : 指定代码的package名称
-l <languange> : 使用的语言(Java/C) 默认是java
-t : 为代码生成测试用例
-ss : 生成服务端代码 默认不生成
-sd : 生成服务描述文件 services.xml,仅与-ss一同使用
-d <databinding> : 指定databingding,例如,adb,xmlbean,jibx,jaxme and jaxbri
-g : 生成服务端和客户端的代码
-pn <port_name> : 当WSDL中有多个port时,指定其中一个port
-sn <serv_name> : 选择WSDL中的一个service
-u : 展开data-binding的类
-r <path> : 为代码生成指定一个repository
-ssi : 为服务端实现代码生成接口类
-S : 为生成的源码指定存储路径
-R : 为生成的resources指定存储路径
–noBuildXML : 输出中不生成build.xml文件
–noWSDL : 在resources目录中不生成WSDL文件
–noMessageReceiver : 不生成MessageReceiver类

 

 WSDL2Java  -p com.hupun.pass.client.dingjie.webservice.xmlclass -ss -uri http://xxx.xxx.xxx.xxx:6384/ws/r/aws_ttsrv2?WSDL -o src  -f  -O 600 
分享到:
评论

相关推荐

    Axis2生成webservice客户端通用依赖包

    总的来说,"Axis2生成webservice客户端通用依赖包"是一个方便开发者快速搭建和使用Web服务客户端的解决方案,它集成了必要的库,简化了项目集成过程,提高了开发效率。在实际开发中,理解和掌握这一方法将极大地提升...

    基于axis2实现的webservice简单实现(客户端+服务端)。

    【标题】中的“基于axis2实现的webservice简单实现(客户端+服务端)”表明了本文将探讨如何使用Apache Axis2框架来创建和消费Web服务。Apache Axis2是Apache软件基金会开发的一个Web服务引擎,它提供了高效且灵活的...

    axis2组建webservice,客户端必须的jar包

    Axis2是Apache软件基金会开发的一个开源Web服务框架,它提供了构建高效、可扩展的Web服务的能力。本话题将详细阐述如何使用Axis2创建Java Web服务以及客户端在调用这些服务时所需的重要依赖库。 1. **Axis2组件**:...

    axis开发webservice客户端

    标题中的“axis开发webservice客户端”指的是使用Apache Axis框架创建并使用Web服务客户端的过程。Apache Axis是Java平台上的一个开源工具,它简化了SOAP(Simple Object Access Protocol)Web服务的开发,包括...

    axis2开发webservice(二)

    资源包含了:axis2-1.7.4-bin.zip、axis2-1.7.4-war.zip、axis2-eclipse-...备注:资源超过了70M 分成了3部分 见axis2方式开发webservice(一)和 axis2方式开发webservice(二)、 axis2方式开发webservice(三)

    axis2开发webservice

    标题 "Axis2 开发 WebService" 指的是使用 Apache Axis2 框架在 Eclipse 集成开发环境中创建和部署 WebService 的过程。Apache Axis2 是一个强大的 WebService 引擎,它提供了高性能、灵活且可扩展的架构,支持多种...

    使用cxf wsdl2java生成webservice客户端

    使用cxf wsdl2java生成webservice客户端命令

    axis2方式开发webservice

    资源包含了:axis2-1.7.4-bin.zip、axis2-1.7.4-war.zip、axis2-eclipse-...备注:资源超过了70M 分成了2部分 见axis2方式开发webservice(一)和 axis2方式开发webservice(二)、 axis2方式开发webservice(三)

    axis2发布webservice和调用axis2服务接口

    在IT行业中,Axis2是Apache软件基金会开发的一个用于构建Web服务和Web服务客户端的框架,主要基于Java语言。本文将详细讲解如何使用Axis2来发布Web服务以及如何生成客户端代码来调用这些服务。 首先,让我们了解...

    axis2客户端调用webService接口,精简jar包

    总的来说,使用Axis2客户端调用WebService接口是一种常见的开发实践,通过精简jar包可以优化项目的体积,提高部署效率。理解这个过程并掌握如何精简jar包,对于任何涉及到Web服务的开发工作都是十分有益的。

    Axis2开发webservice总结.doc

    总结来说,Axis2是Apache软件基金会的一个开源项目,提供了一种高效且灵活的方式来开发和部署Web服务。开发者可以利用其强大的功能来构建复杂的分布式应用程序,实现跨平台的数据交换。理解Web服务的基本原理,熟练...

    axis2开发webservice(三)

    资源包含了:axis2-1.7.4-bin.zip、axis2-1.7.4-war.zip、axis2-eclipse-...备注:资源超过了70M 分成了3部分 见axis2方式开发webservice(一)和 axis2方式开发webservice(二)、 axis2方式开发webservice(三)

    axis2的webService服务器端和客户端开发项目

    本项目将详细介绍如何使用Axis2进行Web服务的服务器端和客户端开发。 1. **Axis2简介** Axis2是基于SOAP(简单对象访问协议)的第二代Web服务引擎,它是Apache Axis1.x的升级版。Axis2提供了一个模块化和可扩展的...

    使用axis自动生成webservice客户端代码.docx

    【使用Axis自动生成WebService客户端代码】是Web服务开发中的一个重要步骤,它简化了与服务交互的复杂性。本文档主要介绍了如何在MyEclipse 7.0环境下利用Axis 1.4工具生成客户端代码,以便调用并测试Webservice。 ...

    使用axis自动生成webservice客户端代码.pdf

    【使用Axis自动生成WebService客户端代码】是Web服务开发中的一个重要步骤,它简化了客户端调用Web服务的过程。本文档主要介绍了如何使用Axis工具生成客户端代码,以Myeclipse7.0为开发环境,axis1.4为工具版本,...

    axis2支持webservice 自动生成代码客户端服务端代码插件

    标题提及的“axis2支持webservice 自动生成代码客户端服务端代码插件”,是指Apache Axis2为Eclipse IDE提供的一套工具,旨在简化Web服务的开发流程。这个插件允许开发者通过WSDL(Web Services Description ...

    client_axis.rar_AxisClient_axis client_axis.client_webservice客户端

    "AxisClient"是Apache Axis的一部分,它为开发人员提供了一种方式来消费Web服务,通过生成Java代理类来调用远程服务的方法。 描述中的“基于axis实现的webservice客户端调用”进一步确认了这个项目的核心功能。使用...

    SpringBoot开发WebService之Axis示例

    总的来说,SpringBoot和Axis的结合为Java开发者提供了一种快速开发Web服务的方法。通过理解这两个工具的核心功能以及如何将它们集成在一起,我们可以更好地利用它们的特性来满足项目需求,同时享受到SpringBoot带来...

Global site tag (gtag.js) - Google Analytics