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;
}
}