Axis2开发WebService客户端——RPC方式

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011328719/article/details/50428510

package client;

import javax.xml.namespace.QName;

import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.rpc.client.RPCServiceClient;

/**
 * 在创建QName对象时,QName类的构造方法的第一个参数表示WSDL文件的命名空间名,
 * 即<wsdl:definitions>元素的targetNamespace属性值,第二个参数指定方法名。
 */

/**
 * invokeBlocking方法有三个参数
 * 第一个参数的类型为QName对象,表示调用的WebService方法名;
 * 第二个参数的类型为Object[], 表示调用的WebService方法的参数值;
 * 第三个参数的类型为Class[],表示调用的WebService方法的返回值类型的Class对象。
 */

/**
 * 注意: 当方法没有参数时,invokeBlocking方法的第二个参数值不能是null,而要使用new Object[]{};
 * 如果被调用的WebService方法没有返回值,应使用RPCServiceClient类的invokeRobust方法,
 * 该方法只有两个参数,它们的含义与invokeBlocking方法的前两个参数的含义相同。
 */

public class RPCClient {

        public String client(String address, String qName, String methodName, Object[] opAddEntryArgs) {
                String ret = null;
                try {
                            // 使用RPC方式调用WebService
                            RPCServiceClient serviceClient = new RPCServiceClient();
                            // 指定调用WebService的URL
                            EndpointReference targetEPR = new EndpointReference(address);
                            Options options = serviceClient.getOptions();
                            options.setTo(targetEPR);
                            QName opAddEntry = new QName(qName, methodName);
                            Class[] classes = new Class[] { String.class };
                            ret = (String) serviceClient.invokeBlocking(opAddEntry,
                            opAddEntryArgs, classes)[0];
                            System.out.println(ret);
                } catch (Exception e) {
                            e.printStackTrace();
                }
                return ret;
         }

}

猜你喜欢

转载自blog.csdn.net/u011328719/article/details/50428510