大家在使用webservice都是希望客户端代码是无侵入的。cxf为此提供了动态客户端
DynamicClientFactory objDynamicClientFactory = JaxWsDynamicClientFactory.newInstance();
Client objClient = objDynamicClientFactory.createClient("http://localhost:8080/cxf_spring/services/hello?wsdl");
Object[] objReObjects = objClient.invoke("sayHello", new Object[]{"skydream"});
System.out.println(objReObjects[0]);
其中一个参数是方法名,后一个参数是调用参数。
使用这个方法有俩个需要注意的地方。
1、jdk一定需要使用环境变量配置的(可能classLoader加载原因)
2、如果服务有接口,且和实现类在不同包中,需要把服务类的命名空间改成接口类的命名空间,不让访问不到方法。如:
@WebService(endpointInterface="com.skydream.cxf.IHelloService",serviceName="helloService",targetNamespace="http://cxf.skydream.com/")
public class HelloServiceImpl implements IHelloService
这样就做到了客户端代码无侵入访问。
ok!