一 在服务器端导入cxf的开发包 编写服务端代码,和使用jdk开发一样,启动服务,看到org.eclipse.jetty.server.AbstractConnector doStart 说明使用cxf的服务。 二 编写客户端代码 此次不使用jdk的命
          一 在服务器端导入cxf的开发包
编写服务端代码,和使用jdk开发一样,启动服务,看到 org.eclipse.jetty.server.AbstractConnector doStart 说明使用cxf的服务。
二 编写客户端代码
此次不使用jdk的命令wsimport,也可以使用wsdl2java命令,在cxf的开发文档里apache-cxf-2.5.9\bin,由于没有配置环境变量,要写wsdl2java的全路径,如果报错,需要加参数
-frontend jaxws21, 格式是:wsdl2java的全路径 -frontend jaxws21 wsdl文档的路径
wsimport 和 上面的那种方式都可以用来生成客户端代码。
 
SEI接口:
package com.ws;
import javax.jws.WebMethod;
import javax.jws.WebService;
@WebService
public interface SayHelloWS {
	@WebMethod
	public String sayHello(String str);
}
 
SEI接口实现:
package com.ws;
import javax.jws.WebService;
@WebService
public class SayHelloWSImpl implements SayHelloWS {
	@Override
	public String sayHello(String str) {
		System.out.println("hello:"+str);
		return "hello:"+str;
	}
}
 
发布:
package com.ws;
import javax.xml.ws.Endpoint;
public class TestServer {
	public static void main(String[] args) {
		String address="http://192.168.1.101:8889/WS/SayHelloWS";
		Endpoint.publish(address, new SayHelloWSImpl());
		System.out.println("发布成功");
	}
}
 
客户端代码:
wsdl2java生成部分:
/ws_cxf_client/src/com/ws/ObjectFactory.java
 /ws_cxf_client/src/com/ws/package-info.java
 /ws_cxf_client/src/com/ws/SayHello.java
 /ws_cxf_client/src/com/ws/SayHelloResponse.java
 /ws_cxf_client/src/com/ws/SayHelloWS.java
 /ws_cxf_client/src/com/ws/SayHelloWSImplService.java
 
 
测试代码:
package com.test;
import com.ws.SayHelloWS;
import com.ws.SayHelloWSImplService;
public class TestClient {
	public static void main(String[] args) {
		SayHelloWSImplService factory=new SayHelloWSImplService();
		SayHelloWS ws=factory.getSayHelloWSImplPort();
		String rees=ws.sayHello("tom");
		System.out.println("client:"+rees);
	}
}
        
             