1.理解JAX-WS
1.1JAX-WS概述
JAX-WS2.0 的全称为 Java API for XML-Based Webservices (JAX-WS) 2.0。JAX-WS 2.0 是对 JAX-RPC 1.0 规范的扩展,是 JAX-RPC 1.1 的后续版本, JAX-RPC 2.0 标准发布不久后便被重新命名为 JAX-WS 2.0。 JAX-WS 2.0 是面向 Java 5 的开发 Web services 的最新编程标准,它提供了新的编程模型和对以往的 JAX-RPC 方式的 Web services 进行了增强。 JAX-WS2.0 (JSR 224)是Sun新的web services协议栈,是一个完全基于标准的实现。在binding层,使用的是the Java Architecture for XMLBinding (JAXB, JSR 222),在parsing层,使用的是the Streaming API for XML (StAX, JSR 173),同时它还完全支持schema规范。
1.2JAX-WS 2.1特性
支持SOAP 1.1(默认)、1.2
支持XML/HTTP Binding
支持WS-Addressing
支持document/literal样式
支持WS-I Basic Profile 1.1
支持消息传输优化机制(Message Transmission Optimization Mechanism,MTOM)
2.准备工作
(1) jdk 1.6,j2ee-eclipse
(2) JAXWS2.2.7-20120813(http://jax-ws.java.net/),下载后解压。
3.在eclipse中新建web工程
在工程下新建目录wssrc,wsdl,build,与src目录平级
4.开始书写第一个web service
package ethan.webservice;
import java.util.List;
import javax.jws.WebMethod;
import javax.jws.WebService;
import ethan.webservice.bean.User;
@WebService
public interface IHello {
@WebMethod
public List sayHello(String user);
}
package ethan.webservice.impl;
import java.util.ArrayList;
import java.util.List;
import javax.jws.WebService;
import ethan.webservice.IHello;
import ethan.webservice.bean.User;
@WebService(endpointInterface = "ethan.webservice.IHello",
portName = "HelloServicePort",
serviceName = "HelloService",
targetNamespace = "http://www.ethanSKY.com/webservice/hello")
public class HelloImpl implements IHello {
@Override
public List sayHello(String user) {
System.out.println("=================start==================");
List users = new ArrayList();
User u1 = new User();
u1.setId("1");
u1.setName("name1");
User u2 = new User();
u2.setId("2");
u2.setName("name2");
users.add(u1);
users.add(u2);
System.out.println("2:"+user);
System.out.println("=================end==================");
return users;
}
}
注意:
@WebService
注释在了Class之上,这告诉了JAXWS,此类为Webservice。
@WebMethod
注释在了public方法上,这告诉了JAXWS,此方法为soap方法。
5.通过Java类编译Webservice
JAX-WS 2.0 有两种开发过程:自顶向下和自底向上。自顶向下方式指通过一个 WSDL 文件来创建Web Service,自底向上是从 Java 类出发创建 Web Service。两种开发过程最终形成的文件包括:
1.SEI。一个SEI对应WSDL中WebService的一个port,在Java中是一个Java接口。
2.SEI实现类。
3.WSDL和XSD文件。
结合公司内项目的特点,我们更多的是碰到以下两种情况:
1. Onsite要我们做一个Webservice或者是客户要求我们提供Webservice接口;
2. Onsite已经有一个Webservice了,现在要我们做客户端集成。
因此,我们选用Server端通过Java Class生成webservice,而客户端通过wsdl生成Java调用类的做法。
JAXWS为我们提供了两个工具:
(1)wsgen
主要用于Server端通过Java类编译成Webservice及相关的wsdl文件
(2)wsimport
主要用于Client端(调用端)通过wsdl编译出调用Server端的Java文件
我们就来生成一下上面的这个Hello,打开命令行工具,输入如下命令:
wsgen -cp /home/ethan/workspace/work/jax-ws-server/WebContent/WEB-INF/classes ethan.webservice.impl.HelloImpl -wsdl -s wssrc -r wsdl
注:
-wsdl参数代表生成webservice
- s参数代表生成的.java文件置于何处
-d 参数代表生成的编译class文件置于何处(这个可以忽略,我们利用eclipse编译)
-r 参数代表生成的.wsdl文件与.xsd文件生成在何处
-cp参数代表classpath,即HelloImpl.class的所在
生成的java文件在wssrc目录下,将其拷贝到src目录。
同时在wsdl目录会生成四个文件,两个是wsdl文件两个是xsd文件。
6.部署webservice
在工程的WEB-INF目录下建立“sun-jaxws.xml”文件,内容如下:
修改web.xml文件,如下:
com.sun.xml.ws.transport.http.servlet.WSServletContextListener
HelloService
com.sun.xml.ws.transport.http.servlet.WSServlet
2
HelloService
/HelloService
将JAXWS2.2.7-20120813中lib目录下的jar包导入工程。
将内容部署到应用服务器中,启动应用服务器,访问:http://localhost:8080/jax-ws-server/HelloService?wsdl,出现内容即代表完成服务端部署。
7.客户端开发
利用wsimport生成客户端
在eclipse中新建java工程,在命令行输入:wsimport -keep -d bin -s src wsdl/HelloService.wsdl
生成的HelloService.java中
将url = new URL(baseUrl, "file:/home/ethan/workspace/work/jax-ws-client/wsdl/HelloService.wsdl");
改为:url = new URL(baseUrl, "http://localhost:8080/jax-ws-server/HelloService");
8.书写测试类:
public class HelloServiceTest {
public static void main(String args[]){
HelloService service = new HelloService();
IHello port = service.getHelloServicePort();
List users = port.open("aaa");
System.out.println(users.size());
}
}
大功告成!