一 在服务器端导入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); } }