在第二天的学习中,我们了解了jaxws如何返回一个List<String>类型的相对复杂的java数据类型给客户端,在今天,我们将更深入一步做一个真正的Java复杂类型的Webservice的传输调用。
目标:
1. 用Webservice调用和返回Java的复杂类型(比如说:List<Student>这样的数据)
1.1制作JAVA BEAN-Person对象
这次我们将返回一个List<Person>类型给客户端。
先来制作我们的Person类,代码如下:
package ctsjavacoe.ws.fromjava.bean;
import java.io.*;
public class Person implements Serializable {
private String name = "";
private int age = 0;
private String gender = "";
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
}
|
1.2制作Service端
package ctsjavacoe.ws.fromjava;
import java.util.ArrayList;
import java.util.List;
import ctsjavacoe.ws.fromjava.bean.*;
import javax.jws.WebMethod;
import javax.jws.WebService;
@WebService
public class JavaComplexType {
@WebMethod
public List<Person> getPerson() {
List<Person> testList = new ArrayList<Person>();
Person p = new Person();
p.setName("abc");
p.setAge(31);
p.setGender("female");
testList.add(p);
p = new Person();
p.setName("def");
p.setAge(33);
p.setGender("male");
testList.add(p);
p = new Person();
p.setName("aaa");
p.setAge(26);
p.setGender("female");
testList.add(p);
return testList;
}
}
|
该Service没有Input,只有一个Output,该Output为一个List<Person>类型,它将返回一个List给客户端,该List中有三条Person结构的数据
此处的Webservice Server端生成的全部详细过程请参见“第一天”教程中的描述。
1. 用wsgen来编译生成相关的java文件,wsdl文件与xsd文件;
2. 将编译时输出至wssrc目录的文件拷贝至src目录;
3. 修改WebContent\WEB-INF目录下的sun-jaxws.xml文件,加入:
<endpoint name='JavaComplexType'
implementation='ctsjavacoe.ws.fromjava.JavaComplexType'
url-pattern='/JavaComplexTypeService' />
|
4.修改WebContent\WEB-INF目录下的web.xml加入:
<servlet>
<servlet-name>JavaComplexType</servlet-name>
<servlet-class>com.sun.xml.ws.transport.http.servlet.WSServlet</servlet-class>
<load-on-startup>2</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>JavaComplexType</servlet-name>
<url-pattern>/JavaComplexTypeService</url-pattern>
</servlet-mapping>
|
5. 将JaxWSProject的WebContent目录下的文件拷贝至tomcat的webapps\JaxWSSample
目录下,并选择全部覆盖;
6.重启Tomcat;
7.打开一个IE浏览器,输入:
http://localhost:9090/JaxWSSample/JavaComplexTypeService?wsdl ,可以看到如下的wsdl输出。
此处的Webservice Client端生成的全部详细过程请参见“第一天”教程中的描述。
1. 把Server端生成的wsdl与xsd拷贝至client工程的wsdl目录下
2. 将ctsjavacoe.ws.fromjava.bean.Person这个类拷贝到client工程的相应的src目录下,因为在第二天中,我们使用的是List<String>,String对应的xsd中的string是webservice的一个基本类型,因此不需要在客户端再造型。
而我们这次的返回是一个List<Person>,这个person类可不是xsd所本身拥有的数据类型,因此当客户端得到webservice的返回时,需要在客户端对这个Person做造型,而造型时需要有一个Object来告诉客户端我造出的型是什么东东,因此这边比第二天教程中多出了一步,即手工拷贝Person类至Client工程。
3. 由于我们继续使用polling方式来书写异步的客户端调用,因此我们还需要打开binding.xml文件,更改一下:
<?xml version="1.0" encoding="UTF-8"?>
<bindings xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/"
wsdlLocation="wsdl/JavaComplexTypeService.wsdl"
xmlns="http://java.sun.com/xml/ns/jaxws">
<bindings node="wsdl:definitions">
<enableAsyncMapping>true</enableAsyncMapping>
</bindings>
</bindings>
|
4. 使用wsimport命令来生成client端调用时所需要的“句柄”
5. 把生成的句柄中的JavaComplexTypeService.java这个文件打开,编辑它,将里面两处Url url=……的地方改成你的Server端实际的Webservice的wsdl地址,而默认它是指向一个本地的wsdl文件的路径
2.2书写Test客户端调用Webservice的Server端
package ctsjavacoe.ws.fromjava;
import javax.xml.ws.Response;
import java.util.*;
import ctsjavacoe.ws.fromjava.bean.*;
public class JavaComplexTypePollingClient {
public static void main(String[] args) {
JavaComplexTypeService service = new JavaComplexTypeService();
JavaComplexType port = service.getJavaComplexTypePort();
Response<GetPersonResponse> getPersonAsync = port.getPersonAsync();
while (!getPersonAsync.isDone()) {
System.out.println("is not done");
}
List<Person> rtnList = new ArrayList<Person>();
try {
GetPersonResponse getPersonResponse = getPersonAsync.get();
rtnList = getPersonResponse.getReturn();
System.out.println("return size======" + rtnList.size());
for (Person p : rtnList) {
System.out.println("person=====" + p.getName() + " "
+ p.getAge() + " " + p.getGender());
}
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
|
当我们在eclipse里键入
getPersonResponse.getReturn():
可以看到jaxws已经帮我们把List<Person>转型过来了,我们只需要用相应的泛型:
List<Person>rtnList = new ArrayList<Person>()去把它接出来就行了。
运行该客户端,得到如下输出:
通过第二天,第三天的学习,我们已经基本掌握了jaxws一般的应用,对于java复杂类型的传输有了全面的了解。
在未来两天的学习中,我们将使用jaxws的MTOM feature,用webservice来传输二进制文件,比如说:jpg/gif图片
分享到:
相关推荐
本教程“5天学会jaxws-webservice编程”旨在帮助你快速掌握JAX-WS的核心概念和技术,以便在短短五天内能够熟练地运用到实际项目中。 首先,我们需要了解Web服务的基础。Web服务基于开放标准,如SOAP(Simple Object...
webservice中用到的jar,xfire-jaxws-1.2.6.jar,xfire-jaxws-1.2.6.jar,xfire-jaxws-1.2.6.jar
4. **注解支持**:使用注解简化了Web服务的定义和实现,如`@WebService`、`@SOAPBinding`等。 5. **动态客户端API**:允许在运行时动态创建和使用Web服务客户端,无需预先知道服务接口的详细信息。 6. **WSDL支持**...
maven 下载jaxws-rt 2.1.4 jar 失败了 其中包含包 com.sun.org.apache.xml.internal resolver 20050927 com.sun.xml.bind jaxb-impl 2.1.7 com.sun.xml.messaging.saaj saaj-impl 1.3.1 ...javax.xml.ws jaxws-api 2.1 ...
jaxws-rt-2.3.3
jaxws-rt-2.2.8.jar java webservice依赖包 在Tomcat中发布webservice时所用到
赠送jar包:cxf-rt-frontend-jaxws-3.0.1.jar; 赠送原API文档:cxf-rt-frontend-jaxws-3.0.1-javadoc.jar; 赠送源代码:cxf-rt-frontend-jaxws-3.0.1-sources.jar; 赠送Maven依赖信息文件:cxf-rt-frontend-jaxws...
还在为找不到jar文件烦心吗,不用了到我空间来有你想要的,持续更新。。。 jaxws-api.jar
【JAX-WS Web服务简介】 JAX-WS(Java API for XML Web Services)是Java平台上用于构建Web服务和客户端的API,它替代了早期的...通过对"jaxws-webservice"的Demo学习,你将能够熟练地运用JAX-WS创建和消费Web服务。
5. **javax.annotation-api-1.2-b03.jar**:此库包含了Java的注解API,如`@WebService`、`@WebMethod`、`@WebResult`等,这些都是在JAX-WS中声明Web服务和操作的关键注解。通过这些注解,开发者可以轻松地在Java类上...
cxf-rt-frontend-jaxws-3.0.16.jar jar包下载3.0.16版本下载
安卓用到的额外的jar包,记录在此以备不时之需
JAX-WS提供了基于注解的编程模型,使得Web服务的开发更加简洁,无需手动编写复杂的XML配置文件。 2. **SOAP**:SOAP是一种基于XML的协议,用于交换结构化和类型化的信息。在Web服务中,SOAP消息作为HTTP请求的主体...
1. **jaxws-api.jar**:这是JAX-WS的API接口定义,包含了服务端和客户端的接口,如`javax.jws.WebService`注解和相关的数据类型。 2. **jaxws-ri-runtime.jar**:这是JAX-WS运行时实现,提供了服务端和客户端的实现...
**jaxws-api-2.1-1** 是一个与Java API for XML Web Services(JAX-WS)相关的软件包,版本号为2.1-1。JAX-WS是Java平台上的一个标准,用于构建和部署Web服务。它是Sun Microsystems(现已被Oracle公司收购)在Java ...
5. **性能优化**: jaxws-ri-2.3.0可能包含了一些性能优化,例如更快的序列化/反序列化机制,更高效的内存管理等。 总之,JAX-WS是Java世界中构建和使用Web服务的强大工具,而jaxws-ri-2.3.0则是开发者实现这一功能...
【基于jaxws-ri的Web服务项目】 在Java世界中,Web服务是一种常见的跨平台通信方式,它允许不同系统间的应用程序通过HTTP协议交换数据。本项目是基于Java API for XML Web Services (JAX-WS) 的参考实现——JAXWS-...
5. **JAXWS-RI实现**: JAX-WS 2.1的Reference Implementation (RI)提供了一个完整的实现,包括工具和运行时环境,便于开发者快速上手。 6. **注解增强**: 提供了更多的注解,如`@WebService`、`@WebMethod`、`@...
1. **jaxws-api.jar**:这是JAX-WS的API规范,定义了与Web服务相关的接口和类,如`javax.xml.ws.WebServiceClient`和`javax.jws.WebMethod`等。 2. **jaxws-rt.jar**:运行时库,包含了实现JAX-WS规范所需的所有类...
jaxws-api.jar jaxws-rt.jar jaxws-rt-javadoc.jar jaxws-tools.jar jaxws-tools-javadoc.jar jsr181-api.jar management-api.jar mimepull.jar policy.jar saaj-api.jar saaj-impl.jar stax-ex.jar stax2...