5天学会jaxws-webservice编程第三天

前言:

在第二天的学习中,我们了解了jaxws如何返回一个List<String>类型的相对复杂的java数据类型给客户端,在今天,我们将更深入一步做一个真正的Java复杂类型的Webservice的传输调用。

目标:

1. 用Webservice调用和返回Java的复杂类型(比如说:List<Student>这样的数据)

一、编写Server端

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结构的数据

1.2编译

此处的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输出。

一、编写Client端

2.1编译前的准备

此处的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图片

时间: 2024-12-21 11:09:31

5天学会jaxws-webservice编程第三天的相关文章

CUDA编程(三)评估CUDA程序的表现

CUDA编程(三) 评估CUDA程序的表现 上一篇博客我们基本上搭建起来了CUDA程序的骨架,但是其中并没有涉及到我们之前不断提到的并行加速,毕竟只有当我们的程序高并行的运行在GPU上才能大大缩短运行时间.不过在加速之前我们还有一件非常重要的事情需要考虑,那就是我们的程序到底有没有一个好的表现,也就是我们要准确计算程序的运行时间,这对之后的程序优化也有至关重要的作用,所以值得我们去仔细研究一下~ 这里所谓的计算运行时间也不是单纯意义上的看运行时间,更重要的是我们要通过核函数的运行时间去计算程序实

C#高级编程(第三版)下载34.97 MB(最好用迅雷下)

问题描述 C#高级编程(第三版)下载34.97MB(最好用迅雷下)下载地址: 解决方案 解决方案二:看大小估计是扫描版本的,不过还是谢谢LZ的分享.解决方案三:速度不错,谢谢

Javascript面向对象编程(三):非构造函数的继承

Javascript面向对象编程(三):非构造函数的继承 作者: 阮一峰 日期: 2010年5月24日 这个系列的第一部分介绍了"封装",第二部分介绍了使用构造函数实现"继承". 今天是最后一个部分,介绍不使用构造函数实现"继承". 一.什么是"非构造函数"的继承? 比如,现在有一个对象,叫做"中国人". var Chinese = { nation:'中国' }; 还有一个对象,叫做"医生&qu

5天玩转C#并行和多线程编程 —— 第三天 认识和使用Task

5天玩转C#并行和多线程编程系列文章目录 5天玩转C#并行和多线程编程 -- 第一天 认识Parallel 5天玩转C#并行和多线程编程 -- 第二天 并行集合和PLinq 5天玩转C#并行和多线程编程 -- 第三天 认识和使用Task 5天玩转C#并行和多线程编程 -- 第四天 Task进阶 5天玩转C#并行和多线程编程 -- 第五天 多线程编程大总结   对于多线程,我们经常使用的是Thread.在我们了解Task之前,如果我们要使用多核的功能可能就会自己来开线程,然而这种线程模型在.net

三步学会Java Socket编程

第一步 充分理解Socket 1.什么是socket 所谓socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄.应用程序通常通过"套接字"向网络发出请求或者应答网络请求. 以J2SDK-1.3为例,Socket和ServerSocket类库位于java.net包中.ServerSocket用于服务器端,Socket是建立网络连接时使用的.在连接成功时,应用程序两端都会产生一个Socket实例,操作这个实例,完成所需的会话.对于一个网络连接来说

怎样才能成为PHP高手?学会“懒惰”的编程

PHP是一门高效的网络编程语言,由于它具有编写灵活.运行快速等优点,迅速成为Web程序员的首选语言.前不久的一份权威调查表明,现在已经有31.6%的网站使用PHP作为主要的服务器端编程语言. 但是,要成为一名PHP编程高手却并不容易.并不像很多人想象的那样,只要能够飞快地编写几条简单的代码去解决一个复杂的问题就是PHP编程高手了,真正的PHP高手还需要考虑更多的其它问题.以下三条准则是一名成熟的PHP程序员在编程中应该首先遵循的准则. 1.懒惰是金 2.编写漂亮的代码 3.追求程序的速度,而不是

C#调用JAX-WS WebService超时

问题描述 第三方用JAVA的JAX-WS开发的WebService,我这边用C#的添加web引用进行调用返回超时,已经设置了超时时间,但是就是接收不到返回.对方接口返回数据格式是对象list和单个对象,求大神解答,急!!! 解决方案 解决方案二:就算是你胡乱发送给一个http请求,对方也应该有返回的.你可以先跟对方沟通一下,看看是不是"一定会有返回".如果你确定了上述"胡乱发送请求"本身就会超时,再来考虑更多的.解决方案三:引用楼主ji_mingxing的回复: 已

ASP 3.0高级编程(三十一)

编程|高级 7.1.2 语义或"运行期"错误语法错误的发现和处理是令人烦恼的,但在编程中会遇到一些真正"令人兴奋"的另一类型的错误--语义错误(semantic error)或称"运行期"错误(runtime error).这类错误仅当运行一个脚本代码或其他程序时才会发现.换句话说完整有效的代码已经通过解释器或编译器的解释或编译,在执行时产生了错误.术语"运行期错误"通过是指语义错误的结果,也就是说这类错误存在于代码的语义中,

ASP 3.0高级编程(三十三)

编程|高级 7.4.2 VBScript错误处理在VBScript中,可以使脚本解释器不处理其找到的任何错误,并且使用On Error Resume Next语句继续运行下个语句.一旦这个语句已被处理,脚本引擎将继续运行后面的程序,而不理会已经发现的任何错误.然而,这种过程仅适用于顺序执行语句的环境,换句话说,不适用于嵌套的函数或子程序.1. 使用On Error Resume Next语句一个错误在子程序中出现时,如果没有运行On Error Resume Next语句,那么错误将被交给调用它