`
white_crucifix
  • 浏览: 96738 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Spring Web Service 简明教程(二) —— 测试篇

阅读更多
      其实这是一篇很水的文章,因为我并没有打算讲spring-ws-test包里提供的测试API,只是为了简单讲述一下client的API的使用而借用了junit,就像前一篇最后说的,实际使用webserviceTemplate时不会一次一次去new,而是依赖注入,所以,这篇就是例子。

      在编写测试代码之前,首先做一点准备,首先我在我的项目架构里添加了这么些东西。高亮显示的test目录(好吧,高亮的下面一行)以下级别的东西。


      我是使用maven来编写的,所以会有这样的结构,总之不管是什么样的目录结构,你都需要将这里的java目录和resources目录设置为classpath,在eclipse里是classpath,在intelliJ里设置为test sources和test resources。

      注意: 图里看到的spring-ws-servlet.xml和user.xsd及存放路径并不是前文使用到的,这是拷贝过来,由于想将测试环境和开发环境的spring配置文件区分开,所以将这两个文件拷贝到test的resources目录下……好吧,其实是骗人的,因为直接使用开发环境(即/WEB-INF/)目录下的配置文件,请求发送时抛错了。。。。
Caused by: java.io.FileNotFoundException: class path resource [WEB-INF/spring-ws-servlet.xml] cannot be opened because it does not exist

Caused by: java.lang.IllegalArgumentException: xsd 'class path resource [WEB-INF/user.xsd]' does not exist


      额,题外话了,具体原因还得找时间深入源码去看,现在不管它。

      首先修改下spring-ws-servlet.xml,当然,是用于测试的那个xml,正式的xml不需要改变。将
<sws:xsd location="/WEB-INF/user.xsd" />

改为
<sws:xsd location="classpath:user.xsd" />


添加一段配置,我们要将webserviceTemplate配置在spring里,也是同一个文件,但是这一段最好在正式的配置文件里也加上去,尽管我们现在是用不到:
<bean id="webServiceTemplate" class="org.springframework.ws.client.core.WebServiceTemplate">
        <property name="marshaller" ref="jaxbMarshallerBean"/>
        <property name="unmarshaller" ref="jaxbMarshallerBean"/>
</bean>

      说明 :还记得上一篇配置的marshaller吗,其实在上一篇中并没有作用,我们要在这里将它注入进WebServiceTemplate中,这样我们取到的template实例将能够使用转型+发送合二为一的方法marshalSendAndReceive()。在template中分别注入了由Object到XML的转换器marshaller,和由XML到Object的转换器unmarshaller,但是有趣的是两者是同一个bean,这是一个的简化之处。

      然后,简单的测试代码:
import com.zchen.User;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.ws.WebServiceMessage;
import org.springframework.ws.client.core.SourceExtractor;
import org.springframework.ws.client.core.WebServiceMessageCallback;
import org.springframework.ws.client.core.WebServiceMessageExtractor;
import org.springframework.ws.client.core.WebServiceTemplate;
import org.springframework.ws.support.MarshallingUtils;
import org.springframework.xml.transform.StringSource;

import javax.xml.transform.Source;
import javax.xml.transform.TransformerException;
import javax.xml.transform.stream.StreamResult;
import java.io.IOException;
import java.io.StringWriter;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:spring-ws-servlet.xml")
public class ClientTest {

    private String uri = "http://127.0.0.1:8080/userService/user.wsdl";
    @Autowired
    private WebServiceTemplate webServiceTemplate;

    @Test
    public void testMarshalSend() throws Exception {
        User user = new User(1, "chenzhouce");
        User returnUser =(User)webServiceTemplate.marshalSendAndReceive(uri, user);
        System.out.println(returnUser);
    }
}


      说明:因为配置文件放在classpath目录下了,所以@ContextConfiguration("classpath:spring-ws-servlet.xml")这样就可以了。测试代码是上一篇文章最后的例子,但是因为有了依赖注入而简化了大量代码。应该比较好理解。

     再来看一个使用基本的发送方法的例子 :
    @Test
    public void testSourceSend() throws Exception {
        User user = new User(1, "chenzhouce");
        
        StringWriter prepareData = new StringWriter();
        webServiceTemplate.getMarshaller().marshal(user, 
                      new StreamResult(prepareData));
        String userString = prepareData.toString(); // #a

        Source requestPayload = new StringSource(userString);
        StringWriter sw = new StringWriter();
        StreamResult result = new StreamResult(sw);
        boolean ret =  webServiceTemplate.sendSourceAndReceiveToResult(uri, requestPayload, result);                            //#b
        System.out.println("Return :" + ret);
        System.out.println(sw);

        Source resultSource = new StringSource(sw.toString());
        User user = (User) webServiceTemplate.getUnmarshaller()
                       .unmarshal(resultSource);
        System.out.println(user);                   //#c
    }

      说明:请先直接看发送方法sendSourceAndReceiveToResult,它需要的参数是Source类型的requestPayload和Result类型的result,前者是发送的参数,后者是返回的结果。
               区域#a是将User对象转换为Xml字符串, 区域#b是发送,区域#c是取到返回的结果,包括返回的值ret(true/false)以及填充后的sw变量,即返回的xml字符串。

      再来看一种方法,使用场景比较少。
@Test
public void testSendCallback() throws Exception {
    User user = new User(1, "chenzhouce");
    User returnUser = (User) webServiceTemplate
       .marshalSendAndReceive(uri, user, new WebServiceMessageCallback() {
          public void doWithMessage(WebServiceMessage message) throws
                     IOException, TransformerException {
              System.out.println(message);
          }
    });
    System.out.println(returnUser);
}

        这里主要展示了WebServiceMessageCallback的简单使用。回调函数,顾名思义,请求发送返回后执行的方法。内部实现一个方法doWithMessage,参数message对我们而言感觉用处不大。这个方法最坑爹的是作为一个同步顺序执行的send方法,在回掉函数内实现的逻辑完全可以写在send之后吧…… 除非send是异步的...
    
        还有另一种方法,是利用SourceExtractor这个参数,和callback类似的编码方式,也是自己实现方法的匿名内部类,不过实现方法中能取到的参数信息量比上面那种多,但是我没仔细研究过,就不列出来了。

       好吧,这其实不是个严谨的单元测试篇章,所有的结果都是以sout的方式打印出来。而对于spring-ws-test包提供的更专业的sws单元测试API以后看心情再去研究吧。。。

      源码同在上一篇提供的Github repo里,直接传送门:
      https://github.com/chenzhouce/spring-webservice-demo/blob/master/src/test/java/ClientTest.java
  • 大小: 13.8 KB
分享到:
评论

相关推荐

    Spring Web Service实例

    Spring Web Service是Spring社区基于Spring提供的一个关注于创建”文档驱动”的Web Service的模块, 它的主要目标是方便基于”契约优先”(Contract-First)的SOAP服务的开发. 好像没有多少人讨论, 大多数的话题都是...

    Spring Web Service 实战篇(1)

    《Spring Web Service实战篇(1)》主要涵盖了在Java环境中使用Spring框架构建Web服务的相关技术。本实战篇将深入探讨Spring Web Service的核心概念、架构设计以及实现步骤,旨在帮助开发者熟练掌握这一强大的工具。 ...

    Spring2.5开发简明教程中文版(1-4章有书签)

    《Spring2.5开发简明教程中文版》是针对初学者设计的一份全面而实用的教程,涵盖了Spring框架的核心概念和基本用法。本教程共分为1-4章,每章均配有书签,便于读者查阅和复习。下面将详细阐述这四章中的主要知识点。...

    Java Web开发实践教程——从设计到实现(第2版)PPT

    《Java Web开发实践教程——从设计到实现(第2版)》是一本深入探讨Java Web技术的权威指南,尤其适合初学者和有一定基础的开发者。本教程通过PPT的形式,以直观、易懂的方式讲解了从项目规划到实际开发的全过程。在...

    Spring Web Service Demo

    Spring Web Service 简单使用,配合JAX-B生成的Pojo,直接部署即可运行。

    Spring2.5开发简明教程中文版

    通过这个教程,读者可以深入理解Spring的DI、AOP原理,以及如何利用Spring MVC构建Web应用,同时掌握数据持久化和测试等关键技能。尽管教程的更新可能因为作者的工作和个人原因较慢,但它仍然是一个有价值的学习资料...

    spring 2.5开发简明教程

    Spring 2.5 开发简明教程 Spring 是一个开源的 Java 平台,它主要为 J2EE 应用程序提供了一个轻量级的框架,简化了企业级应用的开发。Spring 2.5 版本是该框架的一个重要里程碑,引入了许多新特性和改进,使得开发...

    xfire ibatis spring web service

    这篇博客可能讨论的是如何将这三个技术——XFire、iBatis和Spring——集成在一起,构建一个Web服务应用程序。在这样的集成中,Spring可以管理整个应用的生命周期,包括XFire的Web服务和iBatis的数据访问层。通过...

    Spring Web Flow权威指南.pdf

    《Spring Web Flow权威指南》介绍了Spring Web Flow的构建系统Spring Jumpstart、Spring Web Flow架构和基础知识,并结合示例讲述了Spring Web Flow的高级概念、流执行管理和驱动,同时说明了如何测试流。...

    Web Service实践之——开始XFire

    这篇博客“Web Service实践之——开始XFire”可能详细介绍了如何使用XFire来实现Web服务。 在Web服务的世界里,SOAP(Simple Object Access Protocol)是用于交换结构化信息的标准协议,而WSDL(Web Services ...

    使用XFire+Spring构建Web Service

    【使用XFire+Spring构建Web Service】是一种高效且灵活的方法,尤其适合于那些希望利用Spring框架的优秀特性来开发Web Service应用的开发者。XFire是一个先进的Web Service框架,与Axis2并列为新一代的选择,因其...

    实战Web Service —— 使用Apache CXF开发Web服务的教程

    【标题】:“实战Web Service —— 使用Apache CXF开发Web服务的教程” 【内容详解】: Web服务是一种基于开放标准的、平台无关的接口技术,它允许不同系统间的应用程序进行交互。Apache CXF是一个开源的Java框架,...

    Spring Web MVC外文翻译

    与 Spring Web MVC 并行地,Spring Framework 5.0 引入了响应式栈——一个名为 Spring WebFlux 的 Web 框架,该框架的命名也是基于其源模块 `spring-webflux`。本节将重点讨论 Spring Web MVC。 #### 二、...

    Web Service实例(Spring+Hibernate+Web Service)

    【Web Service实例详解——Spring+Hibernate+Web Service】 在当今的软件开发中,Web Service作为一项重要的技术,被广泛应用于不同系统之间的数据交互和集成。本实例将详细讲解如何使用Spring、Hibernate和Web ...

    Spring Web Services API(Spring Web Services 开发文档).CHM

    Spring Web Services 官网 Spring Web Services API。 Spring Web Services 开发文档。

    Spring应用开发实战Web Service WS

    Spring是目前非常流行的Java应用框架,其提供了丰富的开发组件,WS(Web Service)是其中重要的组成部分。Web Service是一种基于Web的分布式计算技术,它使得不同应用程序能够通过Internet通信和交互。Spring对WS的...

    Spring Webscripts Reference Documentation

    这篇文档深入解析了Spring Webscripts的使用和配置,帮助开发者更好地理解和应用这一技术。 在Spring框架中,Webscripts主要用于构建可复用、可维护的Web应用逻辑。它们将业务逻辑、数据处理和视图渲染整合在一起,...

Global site tag (gtag.js) - Google Analytics