Axis2 WebService客户端的三种方式

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

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

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

  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.       // 第一个参数命名空间地址,第二个参数是命名空间前缀   
  112.       OMNamespace omNs = fac.createOMNamespace(tns, "");    
  113.       // 第一个参数是构建标签名称,第二个参数是命名空间  
  114.       OMElement method = fac.createOMElement("getPrice", omNs);    
  115.       OMElement symbol = fac.createOMElement("symbol", omNs);  
  116.       // 标签设值    
  117.       symbol.setText("13");    
  118.       //symbol.addChild(fac.createOMText(symbol, "Axis2 Echo String "));   
  119.       // 添加子标签   
  120.       method.addChild(symbol);    
  121.       // 构建报文  
  122.       method.build();    
  123.       // 发送请求返回报文    
  124.       OMElement result = sender.sendReceive(method);    
  125.     
  126.       System.out.println(result);    
  127.     
  128.     } catch (AxisFault axisFault) {    
  129.       axisFault.printStackTrace();    
  130.     }    
  131.   }    
  132.     
  133.  /**  
  134.   * 为SOAP Header构造验证信息,  
  135.   * 如果你的服务端是没有验证的,那么你不用在Header中增加验证信息  
  136.   *  
  137.   * @param serviceClient  
  138.   * @param tns 命名空间  
  139.   * @param user  
  140.   * @param passwrod  
  141.   */    
  142.   public void addValidation(ServiceClient serviceClient, String tns , String user, String passwrod) {    
  143.     OMFactory fac = OMAbstractFactory.getOMFactory();    
  144.     OMNamespace omNs = fac.createOMNamespace(tns, "nsl");    
  145.     OMElement header = fac.createOMElement("AuthenticationToken", omNs);    
  146.     OMElement ome_user = fac.createOMElement("Username", omNs);    
  147.     OMElement ome_pass = fac.createOMElement("Password", omNs);    
  148.         
  149.     ome_user.setText(user);    
  150.     ome_pass.setText(passwrod);    
  151.         
  152.     header.addChild(ome_user);    
  153.     header.addChild(ome_pass);    
  154.     
  155.     serviceClient.addHeader(header);    
  156.   }    
  157.     
  158.       
  159.   /**  
  160.    * 方法三:利用axis2插件生成客户端方式调用  
  161.    *  
  162.    */    
  163.   public static void testCodeClient() {    
  164.     try {    
  165.       String url = "http://localhost:8080/axis2ServerDemo/services/StockQuoteService";    
  166.       StockQuoteServiceStub stub = new StockQuoteServiceStub(url);    
  167.       GetPrice request = new GetPrice();    
  168.       request.setSymbol("ABCD");    
  169.       GetPriceResponse response = stub.getPrice(request);    
  170.       System.out.println(response.get_return());    
  171.     } catch (org.apache.axis2.AxisFault e) {    
  172.       e.printStackTrace();    
  173.     } catch (java.rmi.RemoteException e) {    
  174.       e.printStackTrace();    
  175.     }    
  176.     
  177.   }    
  178.     
  179.   public static void main(String[] args) {    
  180.      StockQuoteClient.testRPCClient();    
  181. // StockQuoteClient.testDocument();    
  182.     // StockQuoteClient.testCodeClient();    
  183.     
  184.   }    
  185. }    

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类

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

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

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

  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.       // 第一个参数命名空间地址,第二个参数是命名空间前缀   
  112.       OMNamespace omNs = fac.createOMNamespace(tns, "");    
  113.       // 第一个参数是构建标签名称,第二个参数是命名空间  
  114.       OMElement method = fac.createOMElement("getPrice", omNs);    
  115.       OMElement symbol = fac.createOMElement("symbol", omNs);  
  116.       // 标签设值    
  117.       symbol.setText("13");    
  118.       //symbol.addChild(fac.createOMText(symbol, "Axis2 Echo String "));   
  119.       // 添加子标签   
  120.       method.addChild(symbol);    
  121.       // 构建报文  
  122.       method.build();    
  123.       // 发送请求返回报文    
  124.       OMElement result = sender.sendReceive(method);    
  125.     
  126.       System.out.println(result);    
  127.     
  128.     } catch (AxisFault axisFault) {    
  129.       axisFault.printStackTrace();    
  130.     }    
  131.   }    
  132.     
  133.  /**  
  134.   * 为SOAP Header构造验证信息,  
  135.   * 如果你的服务端是没有验证的,那么你不用在Header中增加验证信息  
  136.   *  
  137.   * @param serviceClient  
  138.   * @param tns 命名空间  
  139.   * @param user  
  140.   * @param passwrod  
  141.   */    
  142.   public void addValidation(ServiceClient serviceClient, String tns , String user, String passwrod) {    
  143.     OMFactory fac = OMAbstractFactory.getOMFactory();    
  144.     OMNamespace omNs = fac.createOMNamespace(tns, "nsl");    
  145.     OMElement header = fac.createOMElement("AuthenticationToken", omNs);    
  146.     OMElement ome_user = fac.createOMElement("Username", omNs);    
  147.     OMElement ome_pass = fac.createOMElement("Password", omNs);    
  148.         
  149.     ome_user.setText(user);    
  150.     ome_pass.setText(passwrod);    
  151.         
  152.     header.addChild(ome_user);    
  153.     header.addChild(ome_pass);    
  154.     
  155.     serviceClient.addHeader(header);    
  156.   }    
  157.     
  158.       
  159.   /**  
  160.    * 方法三:利用axis2插件生成客户端方式调用  
  161.    *  
  162.    */    
  163.   public static void testCodeClient() {    
  164.     try {    
  165.       String url = "http://localhost:8080/axis2ServerDemo/services/StockQuoteService";    
  166.       StockQuoteServiceStub stub = new StockQuoteServiceStub(url);    
  167.       GetPrice request = new GetPrice();    
  168.       request.setSymbol("ABCD");    
  169.       GetPriceResponse response = stub.getPrice(request);    
  170.       System.out.println(response.get_return());    
  171.     } catch (org.apache.axis2.AxisFault e) {    
  172.       e.printStackTrace();    
  173.     } catch (java.rmi.RemoteException e) {    
  174.       e.printStackTrace();    
  175.     }    
  176.     
  177.   }    
  178.     
  179.   public static void main(String[] args) {    
  180.      StockQuoteClient.testRPCClient();    
  181. // StockQuoteClient.testDocument();    
  182.     // StockQuoteClient.testCodeClient();    
  183.     
  184.   }    
  185. }    

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类

猜你喜欢

转载自blog.csdn.net/wen430821/article/details/54705888