最近在项目中使用webservice连接调用其他系统的接口,自己学习了一下webservice。demo如下
1.基于jdk1.6以上jdk自带的webservice,我们在jdk安装目录下的bin目录下可以看到wsimport.exe的文件,这个文件就是用于webservice的,在命令行输入wsimport我们会看到
下面是webservice接口
@WebService public interface WebServiceServer { public void sayService(); public void sayService(String name); }
webservice服务端实现类
@WebService //@SOAPBinding(style=Style.RPC) public class WebServiceServerImpl implements WebServiceServer { @Override @WebMethod(exclude=true) public void sayService() { System.out.println("此方法不开放"); } @Override public void sayService(String name) { System.out.println("Hi, I'm " + name); } }
发布接口
public class Server { private final static String ADDR = "http://localhost:8888/testWebService/helloWorld"; public static void main(String[] args) { WebServiceServer server = new WebServiceServerImpl(); Endpoint.publish(ADDR, server); } }
此处localhost表示本机,如果在不同机器上使用改为对应的ip地址
发布后访问地址
点击右边的URL?wsdl就可以看到对应的webservice报文信息了
接着我们可以在命令行使用命令生成客户端代码了
wsimport -s . -p com.share.server http://localhost:8888/testWebService/helloWorld?wsdl
生成代码
将.class文件删除即可:
接着客户端代码
public class WebClient { public static void main(String[] args) { WebServiceServerImpl ws = new WebServiceServerImplService().getWebServiceServerImplPort(); ws.sayName("张三"); } }
输出 Hi, I'm 张三 则调用成功
2.基于cxf的
首先我们需要下载Apache-cxf,然后解压配置环境变量,接着查看里面的示例,我们从lib包中选择
asm-3.3.1.jar
cxf-2.6.2.jar
geronimo-servlet_2.5_spec-1.1.2.jar
neethi-3.0.2.jar
wsdl4j-1.6.2.jar
xmlschema-core-2.0.3.jar
jetty-continuation-7.5.4.v20111024.jar
jetty-http-7.5.4.v20111024.jar
jetty-io-7.5.4.v20111024.jar
jetty-security-7.5.4.v20111024.jar
jetty-server-7.5.4.v20111024.jar
jetty-util-7.5.4.v20111024.jar
下面直接上代码
接口
@WebService public interface IBirthAddr { public String getBirthAddr1(String addr); }
实现类
@WebService(endpointInterface="com.share.server_cxf.IBirthAddr") public class BirthAddrImpl implements IBirthAddr { @Override public String getBirthAddr1(String addr) { return "我出生于:" + addr; } }
发布类
public class Publish { public static void main(String[] args) { testJaxwsServerFactoryBean(); } public static void testJaxwsServerFactoryBean() { // 1.创建ServerFactoryBean的对象,用于发布服务 JaxWsServerFactoryBean server = new JaxWsServerFactoryBean(); // 2.设置服务发布地址 server.setAddress("http://192.168.1.100:9999/ws_cxf1"); // 3.设置服务发布的接口 server.setServiceClass(IBirthAddr.class); // 4.设置服务的发布对象 server.setServiceBean(new BirthAddrImpl()); // 5.使用create方法发布服务 server.create(); System.out.println("cxf"); } }
另外你导入cxf文件夹下的lib的全部包注意
需要添加
Stax2-api-3.1.4.jar woodstox-core-asl-4.4.1.jar否则报错
删除:cxf-services-ws-discovery-api-3.1.4.jar
cxf-services-ws-discovery-service-3.1.4.jar
cxf-services-wsn-api-3.1.4.jar
cxf-services-wsn-core-3.1.4.jar
四个包
否则报错
客户端生成代码命令
wsdl2java -d . -p com.share.server http://192.168.1.100:9999/ws_cxf1?wsdl
-d表示当前目录 -d 与 . 之间有空格
-p 指定包名
注意jdk与cxf的版本问题,否则wsdl2java命令不能使用
生成的文件如下:
客户端调用代码
public class Call { public static void main(String[] args) { testClientProxyFactoryBean(); } public static void testClientProxyFactoryBean() { // 1.创建ClientProxyFactoryBean的对象,用于接收服务 JaxWsProxyFactoryBean bean = new JaxWsProxyFactoryBean(); // 2.设置服务的发布地址,表示去哪里过去服务 bean.setAddress("http://192.168.1.3:9998/ws_cxf1"); // 3.设置服务的发布接口,使用本地的代理接口 bean.setServiceClass(IBirthAddr.class); // 4.通过create方法返回接口代理实例 IBirthAddr ws = (IBirthAddr) bean.create(); // 5.调用远程方法 System.out.println(ws.getBirthAddr1("上海")); } }
打印 :我出生于:上海成功